csv文件导入到数据库,php

时间:2017-02-14 22:55:38

标签: php

我正在尝试编写允许将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>

1 个答案:

答案 0 :(得分:0)

首先,您需要连接一个对数据库具有FILE权限的帐户。 (https://dev.mysql.com/doc/refman/5.7/en/privileges-provided.html#priv_file)FILE特权在服务器级别授予,而不仅仅授予特定数据库。

其次,如果没有将文件的完整路径上传到与执行脚本相同的目录,则需要将该文件的完整路径发送到该命令。