这是我到目前为止所得到的:
/**
* @param PDO $db
* @param string $file
*/
function run_sql_file($db, $file) {
$sql = file_get_contents($file);
try {
$affected = $db->exec($sql);
println("$affected row(s) affected");
} catch(PDOException $e) {
exitmsg($e->getMessage());
}
}
它似乎确实运行了所有查询,但它总是给我“0行受影响”。有没有办法获得每个语句受影响的行数?最好与相关查询一起,以及任何错误消息和警告。
答案 0 :(得分:3)
我遇到了同样的问题,例如我正在从文件中读取一系列mysql drop table sqls,我想将它们执行到单个PDO-> exec()中:
$dbh = new PDO('mysql:host=test;dbname=db1', 'user', 'pass');
try {
$dbh->exec('drop table test_table1;drop table test_table2;');
}
catch(PDOException $e)
{
echo $e->getMessage();
die();
}
如果第一个drop sql成功,那么即使第二个sql失败(该表名不再存在)也不会出现异常。只有在第一个失败然后PDO异常升级时,似乎没有办法检查所有sql是否已执行PDO_MYSQLND;
。
答案 1 :(得分:0)
尝试在执行后设置count变量:
$ DB-> EXEC($ SQL);
$ affected = $ db-> rowCount();
答案 2 :(得分:-1)
假设你没有任何会破坏爆炸声明的疯狂SQL ......
/**
* @param PDO $db
* @param string $file
*/
function run_sql_file($db, $file) {
$sql = file_get_contents($file);
$sql_lines = explode(';',$sql);
try {
foreach($sql_lines as $line) {
$affected += $db->exec($line);
}
println("$affected row(s) affected");
} catch(PDOException $e) {
exitmsg($e->getMessage());
}
}