前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >You can't specify target table 'TS_AUTH_ADMIN' for update in FROM clause记录

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

作者头像
微风-- 轻许--
发布2022-04-13 09:10:48
2250
发布2022-04-13 09:10:48
举报
文章被收录于专栏:java 微风

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017/02/22 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档