我正在尝试编写允许将csv文件导入数据库的页面。我有问题让导入工作。它曾经有效,但没有明显的理由它停止工作。我知道脚本正在连接到db,因为我在db中添加了一个手动条目,truncate清除了数据库,但是没有导入数据。我有db表,其中列设置反映了csv中的每一列。任何人都可以协助解决此问题。这是我的代码。
DB-config.php中
<?php
define('_DB_HOST_NAME','localhost');
define('_DB_USER_NAME','root');
define('_DB_PASSWORD','');
define('_DB_DATABASE_NAME','stock_planner');
$dbConnection = mysqli_connect(_DB_HOST_NAME,_DB_USER_NAME,_DB_PASSWORD,_DB_DATABASE_NAME);
?>
的index.php
<?php
if(isset($_POST['submit'])){
include_once 'db-config.php';
if (!$dbConnection)
{
print "<h1>Unable to connect to the database, contact your administrator!</h1>";
}
else
{
$truncate = "TRUNCATE TABLE stock_sales_report";
$file = $_FILES['csv_stock']['name'];
$import = "LOAD DATA LOCAL INFILE '$file'
INTO TABLE stock_sales_report
FIELDS TERMINATED BY ','
OPTIONALLY ENCLOSED BY '\"'
LINES TERMINATED BY '\n'
IGNORE 1 LINES;";
mysqli_query($dbConnection,$truncate);
mysqli_query($dbConnection,$import);
print "<h1>successfully imported.</h1>";
}
}
?>
<!DOCTYPE html>
<html>
<head>
<title>Planner</title>
</head>
<body>
<form method='POST' enctype='multipart/form-data'>
Upload CSV: <input type='file' name='csv_stock' /> <input type='submit' name='submit' value='import' />
</form>
</body>
</html>
答案 0 :(得分:0)
首先,您需要连接一个对数据库具有FILE权限的帐户。 (https://dev.mysql.com/doc/refman/5.7/en/privileges-provided.html#priv_file)FILE特权在服务器级别授予,而不仅仅授予特定数据库。
其次,如果没有将文件的完整路径上传到与执行脚本相同的目录,则需要将该文件的完整路径发送到该命令。