修改表中第一行:
UPDATE table_info SET name= 'test1', address= 'home' LIMIT 1;
修改表中第二行:
不能用"limit 1,1"来表示第二行,select可以用“limit 1,1”表示查询第二行,而update不能。
因为update结合limit使用时,仅能使用“limit n”的语法(否则报错):
UPDATE table_info SET name = 'test' LIMIT 5;
其中“5”,表示前5行。这句话表示更新表中前5行而非第“某”行,若要单独更新第二行还需找其他办法。
那使用update的嵌套子查询(用select把第2行查询出来做条件)可以吗?
UPDATE table_info SET name= 'test1', address= 'home' WHERE name IN(SELECT name FROM table_info LIMIT 1,1);
思路正确,但是仍然报错。因为在Mysql中,不能在同一语句中,先查询(select)出同一表中的某些值,再来对同一表进行修改(update)。个人理解是:可能会在这个过程造成数据混乱。
解决方法是:将select的结果通过一个“中间人”select一次,就可避免。
AS的作用:取别名。
UPDATE table_info SET name= 'test1', address= 'home' WHERE name IN(SELECT Name FROM (SELECT name AS NAME FROM table_info LIMIT 1,1) AS tmp);
修改表中第3行(其余同理) :
UPDATE table_info SET name= 'test1', address= 'home' WHERE name IN(SELECT Name FROM (SELECT name AS NAME FROM table_info LIMIT 2,1) AS tmp);
修改多行(如第4到第5行):
UPDATE table_info SET name= 'test1', address= 'home' WHERE name IN(SELECT Name FROM (SELECT name AS NAME FROM table_info LIMIT 3,2) AS tmp);
参考1:https://blog.csdn.net/m0_62490926/article/details/127358981
参考2:https://blog.csdn.net/flysky2015/article/details/78477704
评论已关闭