mysql:update+limit 按表中行数修改数据(学习笔记,仅供记录) 您所在的位置:网站首页 mysql修改某一列数据前200行 mysql:update+limit 按表中行数修改数据(学习笔记,仅供记录)

mysql:update+limit 按表中行数修改数据(学习笔记,仅供记录)

2024-04-10 00:37| 来源: 网络整理| 查看: 265

 修改表中第一行: 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);



【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有