回答后编辑:我认为这是我自己的代码中的一个错误 – 我不知道它是什么但我继续修复它.见下面的答案.
我正在使用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,$email ) );
$rc = $stmt->rowCount();
echo $rc;
$rc总是为0更新(即使值已明确更改)或1(对于成功插入,如预期的那样).
我错过了什么?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。