mysql中You can’t specify target table for update in FROM clause错误解决方法

mysql中You can't specify target table for update in FROM clause错误的意思是说,不能先select出同一表中的某些值,再update这个表(在同一语句中)。 例以下面这个sql:mysql

update tb_branch_group bg set bg.`status` = 0
WHERE
	bg.id IN (
		SELECT
			b.id
		FROM
			tb_branch_group b
		WHERE
			b.sys_org_code LIKE CONCAT("01", '%')
	)

处理方法:sql

UPDATE tb_branch_group bg
SET bg.`status` = 0
WHERE
	bg.id IN (
		SELECT
			tmp.id
		FROM
			(
				SELECT
					b.id
				FROM
					tb_branch_group b
				WHERE
					b.sys_org_code LIKE CONCAT("002", '%')
			) tmp
	)

也就是说将select出的结果再经过中间表select一遍,这样就规避了错误。oracle

注意,这个问题只出现于mysql,mssql和oracle不会出现此问题。code

相关文章
相关标签/搜索