我可以使用PDO运行多个SQL查询并检索每个语句受影响的行数吗?

时间:2012-09-05 20:59:01

标签: php pdo

这是我到目前为止所得到的:

/**
 * @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行受影响”。有没有办法获得每个语句受影响的行数?最好与相关查询一起,以及任何错误消息和警告。

3 个答案:

答案 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());
    }
}