以下のコードは PHP の PDO で直接動作しますが、Zend\Db\Adapter を使用するとエラーがスローされます。最初の try ブロックは機能しませんが、2 番目のブロックは正常に機能し、すべてのデータがインポートされます。
try {
$dbAdapter = $this->getServiceLocator()->get('Zend\Db\Adapter\Adapter');
$result = $dbAdapter->query("LOAD DATA INFILE '?' INTO TABLE users FIELDS TERMINATED BY ',' ENCLOSED BY '" . '"' . "' LINES TERMINATED BY '\n' IGNORE 1 LINES",
array('/tmp/feed.csv'));
} catch (PDOException $e) {
print "Error1!: " . $e->getMessage() . "<br/>";
}
try {
$dbh = new PDO('mysql:host=localhost;dbname=myapps_test', 'myapps_test_user', 'pwd');
$result = $dbh->exec("LOAD DATA INFILE '/tmp/feed.csv' INTO TABLE users FIELDS TERMINATED BY ',' ENCLOSED BY '" . '"' . "' LINES TERMINATED BY '\n' IGNORE 1 LINES");
$dbh = null;
} catch (PDOException $e) {
print "Error2!: " . $e->getMessage() . "<br/>";
}
最初の試行ブロックで発生するエラー:
Zend\Db\Adapter\Exception\InvalidQueryException: Statement could not be executed
Caused by
PDOException: SQLSTATE[HY000]: General error: 13 Can't get stat of '/db/dev/mysqldata/myapps_test/?' (Errcode: 2)
ロケーション /db/dev/mysqldata/myapps_test は、mysql サーバーのデータベース ファイルがある場所です。