解决MySQL报错:You can‘t specify target table ‘region‘ for update in FROM clause

作者:怪?咖@ 时间:2024-01-27 08:02:39 

前言

首先明确一点这个错误只会发生在delete语句或者update语句,拿update来举例 : update A表 set A列 = (select B列 from A表); 这种写法就会报这个错误,原因:你又要修改A表,然后又要从A表查数据,而且还是同层级。Mysql就会认为是语法错误!

嵌套一层就可以解决,update A表 set A列 = (select a.B列 from (select * from A表) a); 当然这个只是个示例,这个示例也存在一定的问题,比如(select a.B列 from (select * from A表) a)他会查出来多条,然后赋值的时候会报 1242 - Subquery returns more than 1 row

嵌套一层他就可以和update撇清关系,会优先查括号里面的内容,查询结果出来过后会给存起来,类似临时表,可能有的人该好奇了,update A表 set A列 = (select B列 from A表); 我明明加括号了呀,难道不算嵌套吗,当然不算,那个括号根本没有解决他们之间的层次关系!

所谓层次关系就是一条sql当中谁先执行谁后执行,能理解层次关系的尽量要理解,不懂也没关系,下面我提供了四个案例 供大家参考!

示例一

以这张表为例:

DROP TABLE IF EXISTS `region`;
CREATE TABLE `region`
(
   `Id`     int(11) NOT NULL COMMENT '主键id',
   `Name`   varchar(40) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '名称',
   `Pid`    int(11) NULL DEFAULT NULL COMMENT '父类id',
   `status` varchar(2) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '1' COMMENT '1:启用,2:禁用',
   PRIMARY KEY (`Id`) USING BTREE,
   INDEX    `FK_CHINA_REFERENCE_CHINA`(`Pid`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '省市区表' ROW_FORMAT = DYNAMIC;

错误用法:

这个例子就是典型,我要修改region表数据,要将pid 赋值为region当中的某一列数据,这种写法就会报错!mysql不支持 同一张表当中 既要修改又要查询

UPDATE region SET pid = (select pid FROM region WHERE NAME = '市辖区') where name='北京';

解决MySQL报错:You can‘t specify target table ‘region‘ for update in FROM clause

明确一点,这种的不是同一张表是不会报错的!

UPDATE region SET pid = (select id FROM banner) ;

正确用法:

UPDATE region
SET pid = ( SELECT a.pid FROM ( SELECT Pid FROM region WHERE NAME = '市辖区' ) a )
WHERE
NAME = '北京';

示例二

错误用法:

UPDATE region a
SET Name = '1'
WHERE
a.pid IN ( SELECT id FROM region WHERE NAME = '市辖区' );

正确用法:

UPDATE region a
SET Name = '1'
WHERE
a.pid IN ( SELECT b.id FROM (select * FROM region) b WHERE b.NAME = '市辖区' );

示例三

这个sql没有错误示例,只有正确示例,相对来说比较复杂点!

UPDATE region a
SET pid = (
SELECT
b.pid
FROM
( SELECT id, pid FROM region b WHERE b.NAME = '市辖区' ) b
WHERE
a.Pid = b.id
)
WHERE
a.pid IN ( SELECT c.id FROM ( SELECT * FROM region ) c WHERE c.NAME = '市辖区' );

示例四

再来看一个删除的示例

错误用法:

delete from tbl where id in
(
   select max(id) from tbl a where EXISTS
   (
       select 1 from tbl b where a.tac=b.tac group by tac HAVING count(1)>1
   )
   group by tac
);

正确用法:

delete from tbl where id in
(
   select a.id from
   (
       select max(id) id from tbl a where EXISTS
       (
           select 1 from tbl b where a.tac=b.tac group by tac HAVING count(1)>1
       )
       group by tac
   ) a
);

需要注意的地方

(select...) 一定要加个别名,例如:(select...) a否则报错如下:

解决MySQL报错:You can‘t specify target table ‘region‘ for update in FROM clause

来源:https://blog.csdn.net/weixin_43888891/article/details/127000534

标签:mysql,报错
0
投稿

猜你喜欢

  • 详解Python3迁移接口变化采坑记

    2022-12-25 14:29:49
  • 解决pytorch读取自制数据集出现过的问题

    2023-04-23 15:15:43
  • PHP垃圾回收机制超详细介绍

    2023-11-21 23:11:44
  • python打印日志方法的使用教程(logging模块)

    2023-12-10 01:39:14
  • PyQt5主窗口动态加载Widget实例代码

    2023-06-04 21:20:32
  • asp金额大小写转换完全无错版

    2007-09-26 09:38:00
  • jupyter notebook 重装教程

    2022-07-20 09:38:02
  • Python利用numpy实现三层神经网络的示例代码

    2021-07-29 22:04:46
  • TensorFlow在MAC环境下的安装及环境搭建

    2023-09-14 10:32:23
  • 详细介绍pandas的DataFrame的append方法使用

    2022-08-25 07:00:34
  • Windows下MySQL5.6查找my.ini配置文件的方法

    2024-01-22 13:32:38
  • ChatGPT 帮我自动编写 Python 爬虫脚本的详细过程

    2021-09-09 09:13:50
  • VSCode远程SSH免密登录配置实现

    2024-01-04 19:17:07
  • python爬虫爬取幽默笑话网站

    2021-05-31 18:32:58
  • Python 余弦相似度与皮尔逊相关系数 计算实例

    2022-02-24 01:32:52
  • python3 实现自定义切片类为左闭右闭详情

    2022-11-02 11:36:51
  • Python Excel处理库openpyxl详解

    2021-10-18 13:59:04
  • jQuery实现简单复制json对象和json对象集合操作示例

    2024-04-16 09:29:17
  • 使用Python操作excel文件的实例代码

    2023-07-14 10:45:50
  • 为什么python比较流行

    2023-06-26 02:24:22
  • asp之家 网络编程 m.aspxhome.com