我在让我的 PHP 脚本正常工作时遇到了一些麻烦。
我要完成的工作: 在子页面上,我想要一个非常简单的 CSV 文件上传到 MySQL 数据库。它需要 DROP 或 TRUNCATE 表以及 CREATE 或 INSERT INTO,具体取决于先前的解决方案,此 CSV 文件中的一些数据。
我现在的问题是: 我是 PHP 和 MySQL 的初学者,因此无法弄清楚我的脚本为什么不起作用。
我的代码:
PHP:
$connect = mysql_connect("host","user","pass");
mysql_select_db("database",$connect); //select the table
if ($_FILES[csv][size] > 0) {
$file = $_FILES[csv][tmp_name];
$handle = fopen($file,"r");
mysql_query ("
CREATE TABLE IF NOT EXISTS `database`.`table` (
`item_number` VARCHAR( 50 ) CHARACTER SET utf8 COLLATE utf8_danish_ci NOT NULL ,
`item_desq` VARCHAR( 200 ) CHARACTER SET utf8 COLLATE utf8_danish_ci NOT NULL ,
`item_img_path` VARCHAR( 200 ) CHARACTER SET utf8 COLLATE utf8_danish_ci NULL ,
`item_id` INT( 11 ) UNSIGNED NOT NULL AUTO_INCREMENT ,
PRIMARY KEY ( `item_id` )
) ENGINE = MYISAM CHARACTER SET utf8 COLLATE utf8_danish_ci
");
do {
if ($data[0]) {
mysql_query("
INSERT INTO strand_items1 (item_number, item_desq, item_img_path)
VALUES
(
'".addslashes($data[0])."',
'".addslashes($data[1])."',
'".addslashes($data[2])."
)
");
}
} while ($data = fgetcsv($handle,1000,";","\""));
header('Location: import_old.php?success=1'); die;
}
的HTML:
<body>
<form action="" method="post" enctype="multipart/form-data" name="form1" id="form1">
Choose your file: <br />
<input name="csv" type="file" id="csv" />
<input type="submit" name="Submit" value="Submit" />
</form>
</body>
CSV:您在 CSV 中的普通行如下所示
"13371337";"Some description of the item";"NULL";
现在,结果:由此,我得到了一个“成功”的流程,但表中没有数据,据我猜测,数据库上出现了某种无限循环,因为它创建了越来越多的空条目在只有 item_id 自动递增的表中。我哪里出错了,有没有简单的方法来解决这个问题?
这是我在这里的第一个问题,我希望我能满足所有要求。(指出我的新手;问题首先发布在 meta.stackoverflow.com 上;))如果没有,请耐心等待 - 我会密切关注这个问题并迅速回答任何回复和要求。
先感谢您 :)