当前位置:数据库 > MySQL >>

mysql update语句与limit的结合使用

有时候有需要批量更新数据表中从多少行到多少行的某个字段的值
mysql的update语句只支持更新前多少行,不支持从某行到另一行,比如

UPDATE yizuotu_net SET column_name='test' ORDER BY id ASC LIMIT 10;


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

UPDATE yizuotu_net SET column_name='test' ORDER BY id ASC LIMIT 20,10;


更新从20行到30行的某个字段的内容,这样会报错。
解决办法就是采用子查询的方式
UPDATE yizuotu_net column_name='test' WHERE id in (SELECT id FROM (SELECT * FROM yizuotu_net ORDER BY id ASC LIMIT 20,10) AS tt);
这样就能实现更新表中根据id升序排序的第20条到第30条数据的某个字段的内容
CopyRight © 2022 站长资源库 编程知识问答 zzzyk.com All Rights Reserved
部分文章来自网络,