即使我可以从 cli 客户端使用,为什么我不能将 LOAD DATA LOCAL 与 PDO 一起使用?

Why can#39;t I use LOAD DATA LOCAL with PDO even though I can from cli client?(即使我可以从 cli 客户端使用,为什么我不能将 LOAD DATA LOCAL 与 PDO 一起使用?)
本文介绍了即使我可以从 cli 客户端使用,为什么我不能将 LOAD DATA LOCAL 与 PDO 一起使用?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

限时送ChatGPT账号..

我最近将我的 Ubuntu 10.04 开发服务器升级到 14.04.它实际上是全新安装.PHP 版本是 5.4.15,现在是 PHP 5.5.9.MySQL 从 5.1.67 到 5.5.37.

I recently upgraded my Ubuntu 10.04 dev server to 14.04. It is actually a fresh install. PHP version was 5.4.15, and is now PHP 5.5.9. MySQL went from 5.1.67 to 5.5.37.

我正在尝试在新服务器上加载本地数据文件.它可以使用本地 mysql cli 客户端运行命令.使用 PDO 执行时不起作用:

I am trying to LOAD LOCAL DATA INFILE on a new server. It works running the command using the local mysql cli client. It does not work when executing using PDO:

PHP Fatal error:  Uncaught exception 'PDOException' with message 'SQLSTATE[42000]: Syntax error or access violation: 1148 The used command is not allowed with this MySQL version' in /home/ubuntu/mysqltest.php:21
Stack trace:
#0 /home/ubuntu/mysqltest.php(21): PDO->exec('LOAD DATA LOCAL...')
#1 {main}
  thrown in /home/ubuntu/mysqltest.php on line 21

产生错误的代码:

ini_set('mysql.allow_local_infile', 1);
echo "mysql.allow_local_infile: ".ini_get("mysql.allow_local_infile").PHP_EOL;

$options = array(PDO::MYSQL_ATTR_LOCAL_INFILE => 1);
$db = new PDO("mysql:host=$dbHost;dbname=$dbName;charset=utf8", $dbUser, $dbPassword, $options);
$db->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);

$db->exec("CREATE TEMPORARY TABLE tmp_table ( id INT(4), col1 varchar(128) ) ENGINE MYISAM");

$loadSQL = <<<'EOT'
LOAD DATA LOCAL INFILE '/tmp/test.csv' INTO TABLE `tmp_table` FIELDS TERMINATED BY ',' OPTIONALLY ENCLOSED BY '"' ESCAPED BY '\' LINES TERMINATED BY '
' IGNORE 1 LINES (id, col1)
EOT;

$db->exec($loadSQL);

目前为解决问题采取的步骤:

Steps taken so far to address problem:

  • 我已将 local-infile = 1 添加到/etc/mysql/my.cnf 的 [mysql] 和 [mysqld] 部分
  • 我已经检查过 mysql.allow_local_infile = On 在/etc/php5/cli/php.ini 中.
  • DB 用户是 root 用户,因此拥有所有权限.
  • /tmp/test.csv 确实存在并且用户对其拥有完全权限.

推荐答案

这是 php 中的一个错误.请参阅https://bugs.php.net/bug.php?id=68226 用于解释和解决方法.

This is a bug in php. Please see https://bugs.php.net/bug.php?id=68226 for explanation and workaround.

这篇关于即使我可以从 cli 客户端使用,为什么我不能将 LOAD DATA LOCAL 与 PDO 一起使用?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

DeepL的翻译效果还是很强大的,如果我们要用php实现DeepL翻译调用,该怎么办呢?以下是代码示例,希望能够帮到需要的朋友。 在这里需要注意,这个DeepL的账户和api申请比较难,不支持中国大陆申请,需要拥有香港或者海外信用卡才行,没账号的话,目前某宝可以
PHP通过phpspreadsheet导入Excel日期,导入系统后,全部变为了4开头的几位数字,这是为什么呢?原因很简单,将Excel的时间设置问文本,我们就能看到该日期本来的数值,上图对应的数值为: 要怎么解决呢?进行数据转换就行,这里可以封装方法,或者用第三方的
mediatemple - can#39;t send email using codeigniter(mediatemple - 无法使用 codeigniter 发送电子邮件)
Laravel Gmail Configuration Error(Laravel Gmail 配置错误)
Problem with using PHPMailer for SMTP(将 PHPMailer 用于 SMTP 的问题)
Issue on how to setup SMTP using PHPMailer in GoDaddy server(关于如何在 GoDaddy 服务器中使用 PHPMailer 设置 SMTP 的问题)