sql 子查询返回值多于一个,当子查询跟随在=、!=、<、>、>=之后,或子查询用作表达式时
updateWageInfrosetjiangjin=jiangjin+(selectRSumfromRPInfroasRPjoinWageInfroonRP.RPYea...
update WageInfro set jiangjin=jiangjin+(select RSum from RPInfro as RP
join WageInfro on RP.RPYear=WageInfro.wyear and RP.RPMonth=WageInfro.wmonth and RP.Userid=WageInfro.userId)该如何修改 展开
join WageInfro on RP.RPYear=WageInfro.wyear and RP.RPMonth=WageInfro.wmonth and RP.Userid=WageInfro.userId)该如何修改 展开
3个回答
展开全部
select RSum from RPInfro as RP
join WageInfro on RP.RPYear=WageInfro.wyear and RP.RPMonth=WageInfro.wmonth and RP.Userid=WageInfro.userId 这个返回了多个值了,
如果这些值是一样的,你用个top 1,如果不是一样的,应该是你的条件没有写全。
写成如下:
update WageInfro set jiangjin=jiangjin+(select top 1 RSum from RPInfro as RP
join WageInfro on RP.RPYear=WageInfro.wyear and RP.RPMonth=WageInfro.wmonth and RP.Userid=WageInfro.userId)
但看你的语法,我感觉可以写成
update WageInfro set jiangjin=jiangjin+ RSum
from RPInfro as RP join WageInfro as wi on RP.RPYear=wi.wyear and RP.RPMonth=wi.wmonth and RP.Userid=wi.userId
做好备份之后,测试一下,看是否是你想要的结果。
join WageInfro on RP.RPYear=WageInfro.wyear and RP.RPMonth=WageInfro.wmonth and RP.Userid=WageInfro.userId 这个返回了多个值了,
如果这些值是一样的,你用个top 1,如果不是一样的,应该是你的条件没有写全。
写成如下:
update WageInfro set jiangjin=jiangjin+(select top 1 RSum from RPInfro as RP
join WageInfro on RP.RPYear=WageInfro.wyear and RP.RPMonth=WageInfro.wmonth and RP.Userid=WageInfro.userId)
但看你的语法,我感觉可以写成
update WageInfro set jiangjin=jiangjin+ RSum
from RPInfro as RP join WageInfro as wi on RP.RPYear=wi.wyear and RP.RPMonth=wi.wmonth and RP.Userid=wi.userId
做好备份之后,测试一下,看是否是你想要的结果。
展开全部
子查询在=、!=后面,并且是where条件的话,可以用in、not in来替代.
至于<、>、>=之类的,就只能根据实际需求,来获取返回结果中的一个值来做了.
比如说获取返回结果中的最大值或者最小值来做比较..
追记:
上述更新语句如果子查询返回多条的话,只能根据实际需求来获取返回结果中的其中一条数据,
比如说取结果中的最大值(max)或者最小值(min)等.
至于<、>、>=之类的,就只能根据实际需求,来获取返回结果中的一个值来做了.
比如说获取返回结果中的最大值或者最小值来做比较..
追记:
上述更新语句如果子查询返回多条的话,只能根据实际需求来获取返回结果中的其中一条数据,
比如说取结果中的最大值(max)或者最小值(min)等.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
修改如下,供你参考哦
update WageInfro set jiangjin=a.jiangjin+b.RSum
from WageInfro a join RPInfro b on a.wyear=b.RPYear and a.Wmonth=b.RPMonth
and a.userid=b.Userid
update WageInfro set jiangjin=a.jiangjin+b.RSum
from WageInfro a join RPInfro b on a.wyear=b.RPYear and a.Wmonth=b.RPMonth
and a.userid=b.Userid
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询