mysql update语句与limit的结合使用

Posted xinruyi

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql update语句与limit的结合使用相关的知识,希望对你有一定的参考价值。

有时候有需要批量更新数据表中从多少行到多少行的某个字段的值

mysql的update语句只支持更新前多少行,不支持从某行到另一行,比如
UPDATE tb_name SET column_name=‘test‘ ORDER BY id ASC LIMIT 30;

更新前30行的某个字段内容,没什么问题。


 

UPDATE tb_name SET column_name=‘test‘ ORDER BY id ASC LIMIT 20,10;
更新从20行到30行的某个字段的内容,这样会报错。


 

解决办法就是采用子查询的方式
UPDATE tb_name SET column_name=‘test‘ WHERE id in (SELECT id FROM (SELECT * FROM tb_name ORDER BY id ASC LIMIT 20,10) AS tt);
这样就能实现更新表中根据id升序排序的第20条到第30条数据的某个字段的内容

以上是关于mysql update语句与limit的结合使用的主要内容,如果未能解决你的问题,请参考以下文章

mysql update与select结合修改表数据

MySQL--5子查询与连接小结

MySQL上的LIMIT关键字与准备好的语句[重复]

MYSQL-update与select结合使用

MySQL 错误:错误使用 UPDATE 和 LIMIT

通用表表达式实现 UPDATE/DELETE LIMIT