php - SQL用PHP导入CSV文件

标签 php mysql csv

我正在尝试将一个相当大的 CSV 文件导入我的数据库(本地) 该文件是 230MB,大约 880 万行 我遇到的问题是没有打开 CSV 或不知道如何导入它, 文件打开,导入大约 500,000 行,然后退出并显示没有错误或超时或任何其他内容,我只是看到我的网页。

这是代码:

    try {
    $conn = new PDO("mysql:host=$servername;dbname=adresses_database", $username, $password);
    // set the PDO error mode to exception
    $conn->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
    echo "Connected successfully"; 
    $row = 1;
if (($handle = fopen("bagadres.csv", "c+")) !== FALSE) {
    while (($data = fgetcsv($handle, '', ";")) !== FALSE) {
        if (!isset($write_position)) {        // move the line to previous position, except the first line
                $write_position = 0;
        $num = count($data); // $num is 15
        $row++; //i dont need this?
        $stmt = $conn->prepare("INSERT INTO adresses (openbareruimte, huisnummer, huisletter, huisnummertoevoeging, postcode, woonplaats, gemeente, provincie, object_id, object_type, nevenadres, x, y, lon, lat) VALUES (:openbareruimte, :huisnummer, :huisletter, :huisnummertoevoeging, :postcode, :woonplaats, :gemeente, :provincie, :object_id, :object_type, :nevenadres, :x, :y, :lon, :lat)");
        $stmt->bindParam(':openbareruimte', $data[0]);
        $stmt->bindParam(':huisnummer', $data[1]);
        $stmt->bindParam(':huisletter', $data[2]);
        $stmt->bindParam(':huisnummertoevoeging', $data[3]);
        $stmt->bindParam(':postcode', $data[4]);
        $stmt->bindParam(':woonplaats', $data[5]);
        $stmt->bindParam(':gemeente', $data[6]);
        $stmt->bindParam(':provincie', $data[7]);
        $stmt->bindParam(':object_id', $data[8]);
        $stmt->bindParam(':object_type', $data[9]);
        $stmt->bindParam(':nevenadres', $data[10]);
        $stmt->bindParam(':x', $data[11]);
        $stmt->bindParam(':y', $data[12]);
        $stmt->bindParam(':lon', $data[13]);
        $stmt->bindParam(':lat', $data[14]);
    $stmt->execute();
} else {
                $read_position = ftell($handle); // get actual line
                fseek($handle, $write_position); // move to previous position
                fputs($handle, $line);           // put actual line in previous position
                fseek($handle, $read_position);  // return to actual position
                $write_position += strlen($line);    // set write position to the next loop
            }
            fflush($handle);                         // write any pending change to file
        ftruncate($handle, $write_position);     // drop the repeated last line
        flock($handle, LOCK_UN);   
    }
   fclose($handle);
}
    }
catch(PDOException $e)
    {
    echo "Connection failed: " . $e->getMessage();
    }

$conn = null;

我到这里来是为了寻找有关 stackoverflow 和 PHP 手册的帮助,我还搜索了它是否是 mysql 错误。 但我想不通, (有关我使用 linux mint 18 的 mysql 设置的任何建议)

最佳答案

我强烈建议您使用 MySQL 的 LOAD DATA INFILE ,这可能是将 CSV 数据导入 MySQL 表的最快和最有效的方法。您设置的命令看起来像这样:

LOAD DATA INFILE 'bagadres.csv' 
INTO TABLE adresses
FIELDS TERMINATED BY ',' 
ENCLOSED BY '"'
LINES TERMINATED BY '\n'
IGNORE 1 ROWS

如果您的字段没有用引号括起来,或者没有用引号括起来,那么删除或修改 ENCLOSED BY 子句。此外,IGNORE 1 ROWS 将忽略第一行,假设文件的第一行是标题行(即不是实际数据,而是列标签),这是有意义的。

关于php - SQL用PHP导入CSV文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40659478/

相关文章:

ms-access - Access : Truncation error when appending CSV data to tables?

php - 使用 Foreach 从数据库检索结果

php包含语句

mysql - 将oracle for循环转换为mysql循环

javascript - d3.js 中解析 x 属性时出现意外值无穷大

javascript - 从 CSV 文件中选择一些列

php - Braintree 无法执行充电 : Custom field is invalid: description

javascript - 带有隐藏按钮的登录脚本

mysql - wercker.com 连接到 MySQL 数据库

mysql - 不同行上两个列值之间的天数