全网详细解决1093 - You can‘t specify target table ‘xxx‘ for update in FROM clause的错误

这篇具有很好参考价值的文章主要介绍了全网详细解决1093 - You can‘t specify target table ‘xxx‘ for update in FROM clause的错误。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1. 复现错误


今天在工作时,接到一个新需求,就是将app_page_button表中的label_code字段修改为edit,条件如下:

  1. 只更新值为nulllabel_code

  2. 且以/edit/${id}'结尾的option_value

首先使用如下SQL查询满足上述条件的记录,如下代码所示:

SELECT 
	id, label, label_code, option_value 
FROM 
	app_page_button 
WHERE 
	label_code IS NULL 
	AND option_value LIKE '%/edit/${id}';
	
+-----+-------+------------+-----------------------+
| id  | label | label_code | option_value          |
+-----+-------+------------+-----------------------+
| 706 | 编辑  | NULL       | put:common/edit/${id} |
| 710 | 编辑  | NULL       | put:common/edit/${id} |
| 714 | 编辑  | NULL       | put:common/edit/${id} |
+-----+-------+------------+-----------------------+

得到满足上述条件的记录有3条,使用如下SQL语句修改:

UPDATE app_page_button 
SET label_code = 'edit' 
WHERE
	id IN ( 
		SELECT 
			id 
		FROM  
			app_page_button 
		WHERE 
			label_code IS NULL AND option_value LIKE '%/edit/${id}' 
	);

ERROR 1093 (HY000): You can't specify target table 'app_page_button' for update in FROM clause

[hy000][1093] you can't specify target table 'hotelofstaff' for update in fr,免费专栏,sql,数据库,java,后端,运维开发

You can't specify target table 'app_page_button' for update in FROM clause的错误。

2. 分析错误


最近申请的文心一言刚审核通过,可以借助它来分析我的错误,如下图所示:

[hy000][1093] you can't specify target table 'hotelofstaff' for update in fr,免费专栏,sql,数据库,java,后端,运维开发

文心一言的回答,和我的本意不一致。我本想在查询结果中,更新label_code值。

因而,我需要自己分析,来解决这个错误。

You can't specify target table 'app_page_button' for update in FROM clause的含义:不能在同一表(app_page_button)中查询的数据,作为同一表(app_page_button)的更新数据。

3. 解决错误


既然不能先select出同一表中的某些值,再update这个表(在同一语句中),那就采用将查询结果存储到临时表(tmp)表中,id从这个临时表(tmp)中获取,如下代码所示:

UPDATE app_page_button
SET label_code = 'edit'
WHERE
	id IN ( 
		SELECT id 
		FROM ( 
			SELECT 
				id 
			FROM 
				app_page_button 
			WHERE 
				label_code IS NULL AND option_value LIKE '%/edit/${id}' 
		) as tmp 
	);

Query OK, 3 rows affected (0.01 sec)
Rows matched: 3  Changed: 3  Warnings: 0

根据Query OK, 3 rows affected (0.01 sec)这句话可知,已更新成功,从如下SQL可以看到:文章来源地址https://www.toymoban.com/news/detail-768771.html

select 
	id, label, label_code, option_value 
from 
	app_page_button 
where 
	id in (706,710,714);

+-----+-------+------------+-----------------------+
| id  | label | label_code | option_value          |
+-----+-------+------------+-----------------------+
| 706 | 编辑  | edit       | put:common/edit/${id} |
| 710 | 编辑  | edit       | put:common/edit/${id} |
| 714 | 编辑  | edit       | put:common/edit/${id} |
+-----+-------+------------+-----------------------+
3 rows in set (0.00 sec)

到了这里,关于全网详细解决1093 - You can‘t specify target table ‘xxx‘ for update in FROM clause的错误的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包