繁体   English   中英

PHP LOAD DATA INFILE读取文件时出错

[英]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.12,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/zh/pdo.prepare.php

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM