mysql中的affected_rows

在操作mysql语句时,有时需要通过affected_rows来判断语句执行的情况。

例如在事务操作中,就可以通过affected_rows来判断事务是否执行成功,以进一步执行事务的提交或者回滚操作。

对于SELECT操作,mysql_affected_rows()等价于mysql_num_rows(),即查询结果的行数,但是显示使用mysql_num_rows()更加合适。

因此mysql_affected_rows()一般用来在DELETE, INSERT , REPLACE , UPDATE语句执行完成之后判断数据表中变化的行数(如果数据表没有变化,则行数为0)。

  1. DELETE语句执行成功,返回删除的行数,INSERT INTO TABLE VALUES 或者 INSERT INTO TABLES SET 都是返回插入成功的行数,这些是比较明确的。

  2. UPDATE语句执行成功时,则有可能也为0。如果要更新的值与原来的值相同,则affected_rows为0;否则,为更新的行数。

  3. INSERT INTO TABLE VALUES 或者 INSERT INTO TABLES SET 都是返回插入成功的行数,插入成功则返回1,否则返回0 。

  4. INSERT INTO TABLE VALUES … ON DUPLICATE KEY UPDATE … 语句执行成功后,则会有3种情况,当不存在唯一索引冲突时,执行INSERT操作,affected_rows结果为1;当存在主键冲突时,执行UPDATE操作,如果要更新的值与原来的相同,则affected_rows为0,否则为2。

  5. REPLACE INTO TABLE VALUES执行成功 ,如果没有存在唯一索引的冲突,则与INSERT操作没有什么区别affected_rows为1 ;如果存在主键冲突,则会DELETE再INSERT,所以affected_rows的值为2 。


INSERT INTO TABLE VALUES … ON DUPLICATE KEY UPDATE ,当存在唯一索引重复,并成功更新数据之后,受到影响的行数实际上是1,但是affected_rows的值为2。这个数值是mysql手册上规定的,个人猜测应该是因为该语句直接INSERT操作时的affected_rows是1,为了区分两种情况。

参考资料:

http://php.net/manual/zh/function.mysql-affected-rows.php
https://dev.mysql.com/doc/refman/5.7/en/mysql-affected-rows.html

你可能感兴趣的:(MySQL)