使用 PHP/MySQL 导入 CSV 数据:故障排除和优化
本文解决了与使用 PHP/MySQL 将 CSV 数据导入 MySQL 相关的故障排除和优化问题PHP。
担忧和解决方案:
1.文本显示为 0:
确保您的 CSV 文件使用 fgetcsv 中指定的正确分隔符。检查数据库中“文本”列的数据类型。如果没有设置为文本类型,导入的数据可能会被截断。
2.用引号括起来的数据:
如果 CSV 文件中的数据用引号括起来,您可以使用 returned_by 参数在 fgetcsv 中指定。这将从导入的数据中去除引号。
3.忽略标题行:
要忽略标题行,请在开始导入数据之前使用 fgets 函数读取并丢弃 CSV 文件的前 X 行。
4.数据格式保留:
MySQL 默认保留数据格式。小数值导入数据库后将保留为小数。
5.执行时间限制:
如果遇到“超出最大执行时间”错误,请尝试增加 PHP 配置 (php.ini) 中的 max_execution_time 设置。或者,将导入过程分解为较小的批次,以减少服务器上的负载。
优化:
使用 LOAD DATA INFILE 功能:
MySQL提供了LOAD DATA INFILE功能,可以让你将CSV文件直接导入到数据库中,无需循环或解析。此方法比使用 PHP 循环要快得多。
使用 LOAD DATA INFILE 的示例:
<?php $query = <<<EOF LOAD DATA INFILE '$fileName' INTO TABLE tableName FIELDS TERMINATED BY '|' OPTIONALLY ENCLOSED BY '"' LINES TERMINATED BY '\n' (field1,field2,field3,etc) EOF; $db->query($query); ?>
通过使用 LOAD DATA INFILE,您可以简化 CSV 导入过程,提高性能,减少资源消耗。
以上是如何使用 PHP 高效地将 CSV 数据导入 MySQL 并排除故障?的详细内容。更多信息请关注PHP中文网其他相关文章!