下面的代码并不能正常工作:
<?php
var_dump($db->beginTransaction());
$db->query('
INSERT INTO test
(data) VALUES (?)
;',
array(
'Foo'
)
);
print_r($db->query('
SELECT *
FROM test
;'
)->fetchAll());
var_dump($db->rollBack());
print_r($db->query('
SELECT *
FROM test
;'
)->fetchAll());
?>
var_dump的结果显示beginTransaction和rollBack函数都返回了true,因此没有错误。
我原本期望第一个print_r调用会显示一个N项的数组,而第二个调用会显示N-1项。但事实并非如此,它们都显示相同数量的项。
我的 $db->query(< sql >, < values >) 调用实际上与 $pdo->prepare(< sql >)->execute(< values >) 一样(当然还有额外的错误处理)。
所以我认为或者MySQL的事务系统不起作用,或者PDO的实现有问题,或者我看错了些什么。
有人知道问题出在哪里吗?