加入收藏 | 设为首页 | 会员中心 | 我要投稿 应用网_丽江站长网 (http://www.0888zz.com/)- 科技、建站、数据工具、云上网络、机器学习!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

mysql上报出错ERROR 1093

发布时间:2022-03-30 18:45:53 所属栏目:MySql教程 来源:互联网
导读:今天在尝试用子查询来关联更新一个表的收到如下报错: ERROR 1093 (HY000): You cant specify target table v_member_info for update in FROM clause 具体执行的sql如下: MySQL [meminfo] update v_member_info set cust_right_group=0 where id in (sel
       今天在尝试用子查询来关联更新一个表的收到如下报错:
       ERROR 1093 (HY000): You can't specify target table 'v_member_info' for update in FROM clause
具体执行的sql如下:
      MySQL [meminfo]> update v_member_info set cust_right_group=0 where id in (select id from v_member_info where pay_end_date<'2018-01-29' and cust_right_group>0);
      ERROR 1093 (HY000): You can't specify target table 'v_member_info' for update in FROM clause
      原来是mysql在update的时候, 原始表不能出现在where 后面第一层的子查询中;
解决办法:两种改写方法
1)改写成join方式更新
MySQL [meminfo]> update v_member_info as a ,(select id,cust_right_group from v_member_info where pay_end_date<'2018-01-29' and cust_right_group>0) as b set a.cust_right_group=0 where a.id=b.id;
Query OK, 288 rows affected (2.35 sec)
Rows matched: 288 Changed: 288 Warnings: 0
2)或者改成子查询之子查询
MySQL [meminfo]> update v_member_info set cust_right_group=0 where id in(select id from (select id from v_member_info where pay_end_date<'2018-01-29' and cust_right_group>0)a);
小结:Oracle和MySQL还是有区别的,MySQL在update的时候,原始表不能出现在where 后面第一层的子查询当中,至于两种改写的性能的看具体业务和数据量的大小。

(编辑:应用网_丽江站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读