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

 修改表中第一行:

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);

  • 6
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Leo桑

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值