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";
第一个查询的结果是将要更改的行,第二个查询实际上是对其进行更改.
如果这是一个高性能的系统,则可能需要特别注意事务,以防止在这两个查询之间出现新行滑移.
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。