PDO / MySQL rowCount未按预期返回

时间:2012-08-29 02:06:20

标签: php mysql pdo rowcount

回答后编辑:我认为这是我自己的代码中的一个错误 - 我不知道它是什么,但我继续修复它。见下面的答案。

我正在使用MySQL / PHP执行一系列INSERT ... ON DUPLICATE KEY UPDATE语句。我读过的文档表明它的行数将返回:

-1 : an error
0 : update, no changes to row made (i.e. all values duplicated)
1 : row inserted
2 : update performed on row with duplicate key

但是,我只看到0的结果,我应该看到2s(因为我正在观看代码更新各种数据库值。)这是代码:

$stmt = $db->prepare('INSERT INTO sometable (`id`, `name`, `email`) VALUES (?, ?, ?) ON DUPLICATE KEY UPDATE `name` = ?, `email` = ? ;');

$stmt->execute( array ( $id, $name, $email, $name, $email ) );

$rc = $stmt->rowCount();
echo $rc;

$ rc始终为0表示更新(即使值已明确更改)或1(对于成功插入,正如预期的那样。)

我错过了什么? :)

2 个答案:

答案 0 :(得分:3)

尝试使用MySQL函数,如果返回正确的结果,问题将是PDO:rowCount()

$stmt = $db->prepare('INSERT INTO table (`id`, `name`, `email`) VALUES (?, ?, ?) ON DUPLICATE KEY UPDATE `name` = ?, `email` = ? ;');

$stmt->execute( array ( $id, $name, $email, $name, $email ) );

$rc = $db->query("SELECT ROW_COUNT()")->fetchColumn();
echo $rc;

答案 1 :(得分:0)

我认为rowCount()旨在返回SELECT语句中返回的行数。

来自手册

  

PDO :: exec - 执行SQL语句并返回受影响的行数

请尝试使用exec()