解决
所以,这是一种权限错误。在此脚本的早期,我在文件上使用flock()来确保文件没有被另一个脚本写入。删除flock()允许查询运行。现在我只需要确定一种不加载文件的方法,如果它仍然被写入...
我无法在我的php脚本中使用LOAD DATA INFILE。这是脚本的相关部分:
... //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中。我需要改变什么?
答案 0 :(得分:0)
您计划使用$rows
做什么?
您可以通过PDO::QUERY
或PDO::PREPARE
传递查询。
我假设使用PDOStatement::execute
您希望使用PDO::PREPARE
。
$query = $pdo->prepare($sql); $query->execute();
要从查询中获取响应:
$query->fetch()
或$query->fetchAll()
有关在PDO中准备查询的文档,请参阅链接: