php-如何在以前的MySQL操作中获取受影响的行?

mysql_affected_rows是要获取先前的MySQL操作中受影响的行数,但我想获取先前的MysqL操作中受影响的行.
例如:

update mytable set status=2 where column3="a_variable";

在执行此操作之前,某些行的状态已经为2,并且我想在以前的MysqL操作中获取受影响的行,因此无法通过发出以下查询获取它:

select * from mytable where status=2

那么该如何做呢?

解决方法:

使用以下方法可以有效而简单地实现它:

 select * from mytable where column3="a_variable" and status != 2;
 update mytable set status=2 where column3="a_variable";

一个查询的结果是将要更改的行,第二个查询实际上是对其进行更改.

如果这是一个性能的系统,则可能需要特别注意事务,以防止在这两个查询之间出现新行滑移.

相关文章

统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...
前言 之前做了微信登录,所以总结一下微信授权登录并获取用户...
FastAdmin是我第一个接触的后台管理系统框架。FastAdmin是一...
之前公司需要一个内部的通讯软件,就叫我做一个。通讯软件嘛...
统一支付是JSAPI/NATIVE/APP各种支付场景下生成支付订单,返...