修改表中第一行:

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

评论已关闭