在PDO :: commit之后使用PDOStatement :: rowCount结果?

Ozz*_*zzy 8 php mysql pdo transactions pdostatement

在MySQL文档中,有一个关于mysql_affected_rows在事务提交后使用的注释:http: //php.net/manual/en/function.mysql-affected-rows.php

注意:事务
如果您正在使用事务,则需要在INSERT,UPDATE或DELETE查询之后调用mysql_affected_rows(),而不是在COMMIT之后调用.

但是,该PDOStatement::rowCount文档没有这样的说明:http: //www.php.net/manual/en/pdostatement.rowcount.php

这是否意味着在使用PDO对象时INSERT,UPDATE或DELETE查询后提交不会影响受影响的行数?

Nat*_*ate 13

为每个执行的查询返回PDOStatement.您可以在代码中随时使用PDOStatement-> rowCount()(在事务期间或之后,回滚/提交无关紧要).每个对象都负责维护自己.

mysql_affected_rows具有该事务注释的原因是因为它只知道单个mysql连接资源.这意味着当您完成事务(提交/回滚)时,已向DB发送新查询,从而更改正在处理受影响行数的结果.