PHP加载数据文件读取文件时出错


PHP LOAD DATA INFILE Error Reading File

已解决

所以,这是一种权限错误。在这个脚本的早期,我对该文件使用了flock((来确保该文件没有被另一个脚本写入。删除flock((可以运行查询。现在我只需要确定一种方法,如果文件仍在写入…,就不加载它


让LOAD DATA INFILE在我的php脚本中工作时遇到了问题。以下是脚本的相关部分:

... //set $host, $user, etc.
$dsn = "mysql:host=$host;dbname=$database";
$pdo = new PDO($dsn, $user, $password, array(PDO::MYSQL_ATTR_LOCAL_INFILE => 1));
$pdo->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
... //set $sqlFile and $table
$sql = "LOAD DATA INFILE '$sqlFile' REPLACE INTO TABLE `$table`";
echo $sql . "'n";
$rows = $pdo->exec($sql);

运行脚本然后生成:

LOAD DATA INFILE 'D:/pathToTemp/emdr/emdrorders/emdrorders_160314-1947UTC.txt'
REPLACE INTO TABLE `emdrorders`
[PDOException]
SQLSTATE[HY000]: General error: 2 Error reading file 'D:'pathToTemp'emdr'emdrorders'emdrorders_160314-1947UTC.txt'
(Errcode: 13 - Permission denied)

但是,如果我通过mysql-cli运行相同的查询,它就可以工作了。

mysql> LOAD DATA INFILE 'D:/pathToTemp/emdr/emdrorders/emdrorders_160314-1947UTC.txt'
REPLACE INTO TABLE `emdrorders`;
Query OK, 5487 rows affected (0.10 sec)
Records: 5355  Deleted: 132  Skipped: 0  Warnings: 0

我也尝试过使用LOCAL,但$pdo->exec()没有抛出异常,而是返回0,并且数据没有加载到数据库中。

在Windows机器上,我的Mysql版本是5.6.2,PHP版本是5.4.16,并计划将其放在linux服务器上。(我也在Laravel框架内这样做,但我不认为这会导致这个问题。(

由于查询在mysql-cli中工作,但不能通过php工作,所以我只能假设问题出在php设置或pdo中。我需要更改什么?

您计划用$rows做什么?

通过PDO::QUERYPDO::PREPARE传递查询。

根据PDOStatement::execute的使用情况,我认为您希望使用PDO::PREPARE

$query = $pdo->prepare($sql); $query->execute();

要从查询中获取响应,请执行以下操作:$query->fetch()$query->fetchAll()

有关在PDO:中准备查询的文档,请参阅链接

http://www.php.net/manual/en/pdo.prepare.php