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

相關文章
相關標籤/搜索