You can't specify target table 'TS_AUTH_ADMIN' for update in FROM clause记录

2022-04-13 09:10:48 浏览数 (1)

1. 报错:You can't specify target table 'TS_AUTH_ADMIN' for update in FROM clause,

百度查到说是,不能在同一语句中先select出同一表中的某些值,再update这个表 。

我原本的sql是:(删除角色的时候,把管理员拥有的该角色信息也删除)

代码语言:javascript复制
		update TS_AUTH_ADMIN 
		set ROLE_IDS =
		CASE 
		    WHEN ROLE_IDS  in (select ROLE_IDS FROM TS_AUTH_ADMIN WHERE instr(ROLE_IDS,#{roleId} ',')>0) 
		        THEN replace(ROLE_IDS,#{id} ',','') 
		    WHEN ROLE_IDS  in (select ROLE_IDS FROM TS_AUTH_ADMIN WHERE instr(ROLE_IDS,#{roleId})>0) 
		        THEN replace(ROLE_IDS,#{id},'') 
		    ELSE ROLE_IDS END
		和:
		update TS_AUTH_ADMIN 
		set ROLE_NAME =
		CASE 
		    WHEN ROLE_NAME  in (select ROLE_NAME FROM TS_AUTH_ADMIN WHERE instr(ROLE_NAME,#{roleName} ',')>0) 
		        THEN replace(ROLE_NAME,#{roleName} ',','') 
		    WHEN ROLE_NAME  in (select ROLE_NAME FROM TS_AUTH_ADMIN WHERE instr(ROLE_NAME,#{roleName})>0) 
		        THEN replace(ROLE_NAME,#{roleName},'') 
		    ELSE ROLE_NAME END

2. 后来我改成类似如下写法:

代码语言:javascript复制
update TS_AUTH_ADMIN 
		set ROLE_NAME =
		(CASE 
		    WHEN instr(ROLE_NAME,'test2,')>0
		        THEN replace(ROLE_NAME,'test2,','') 
		    WHEN instr(ROLE_NAME,'test2')>0
		        THEN replace(ROLE_NAME,'test2','') 
		    ELSE ROLE_NAME 
		END),
     ROLE_IDS =
		(CASE 
		    WHEN instr(ROLE_IDS,'6,')>0
		        THEN replace(ROLE_IDS,'6,','') 
		    WHEN instr(ROLE_IDS,'6')>0
		        THEN replace(ROLE_IDS,'6','') 
		    ELSE ROLE_IDS END)  

测试通过:(当然我这样改,没有重现问题,不算解决,只是对我的业务是可用的)

3. 网上说再加一层查询可以解决:

代码语言:javascript复制
UPDATE t_user_asset SET f_cashAmount =   
    (  
     SELECT (ua.f_cashAmount 50000) cashAmount FROM t_user_asset ua WHERE ua.f_userId = 290  
  )  
WHERE f_userId = 290  

修改成在select外边套一层,让数据库认为你不是查的同一表的数据

代码语言:javascript复制
UPDATE t_user_asset SET f_cashAmount =   
(  
  SELECT ub.cashAmount FROM  
        (  
             SELECT (ua.f_cashAmount 50000) cashAmount FROM t_user_asset ua WHERE ua.f_userId = 290  
        ) ub  
)  
WHERE f_userId = 290  

这个方法参考:http://blog.csdn.net/yhl_jxy/article/details/50856619

0 人点赞