我的编程空间,编程开发者的网络收藏夹
学习永远不晚

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

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

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

这篇文章主要讲解了“MySQL报错:You can‘t specify target table ‘region‘ for update in FROM clause如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“MySQL报错:You can‘t specify target table ‘region‘ for update in FROM clause如何解决”吧!

前言

首先明确一点这个错误只会发生在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表); 我明明加括号了呀,难道不算嵌套吗,当然不算,那个括号根本没有解决他们之间的层次关系!

示例一

以这张表为例:

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 ) WHERENAME = '北京';

示例二

错误用法:

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

正确用法:

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

示例三

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

UPDATE region a SET pid = (SELECTb.pid FROM( SELECT id, pid FROM region b WHERE b.NAME = '市辖区' ) b WHEREa.Pid = b.id ) WHEREa.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如何解决

感谢各位的阅读,以上就是“MySQL报错:You can‘t specify target table ‘region‘ for update in FROM clause如何解决”的内容了,经过本文的学习后,相信大家对MySQL报错:You can‘t specify target table ‘region‘ for update in FROM clause如何解决这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

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

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

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

目录前言示例一示例二示例三示例四需要注意的地方总结前言首先明确一点这个错误只会发生在delete语句或者update语句,拿update来举例 : update A表 set A列 = (select B列 from A表); 这种写法就
2023-02-01

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

这篇文章主要给大家介绍了关于MySQL报错:You can‘t specify target table ‘region‘ for update in FROM clause的相关资料,文中通过实例代码介绍的非常详细,需要的朋友可以参考下
2023-02-01

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

这篇文章主要讲解了“MySQL报错:You can‘t specify target table ‘region‘ for update in FROM clause如何解决”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思
2023-07-05

MySQL出现You can‘t specify target table for update in FROM clause错误的解决方法

MySQL出现You can‘t specify target table for update in FROM clause错误的解决方法 分析原因解决方法 分析原因 在MySQL中,可能会遇到You can't specif
2023-08-19

You can't specify target table 'table_name' for update in FROM clause - 如何解决MySQL报错:无法在FROM子句中更

在进行MySQL数据库开发过程中,我们有时会遇到以下报错信息:You can't specify target table 'table_name' for update in FROM clause(无法在FROM子句中更新目标表)。这个
2023-10-21

You can't specify target table 'table_name' for update in FROM clause - 如何解决MySQL报错:无法在FROM子句中更

你好,下面是一篇1500字以内的文章,标题为:You can't specify target table 'table_name' for update in FROM clause - 如何解决MySQL报错:无法在FROM子句中更新目
2023-10-22

update mysql row (You can't specify target table 'x' for update in FROM clause)

sql语句(update/delete都会出现此问题)update x set available_material_id = null where id not in (select id from x where additional_info = 1);
update mysql row (You can't specify target table 'x' for update in FROM clause)
2018-03-17

编程热搜

目录