SQL Server用in更新记录时可引用更新表的数据

OA_ChargeBack 是扣款表,ID是他的主键,guid是他的唯一性索引;OA_ChargeBackDetail 是 OA_ChargeBack 的从表,用id和主表的id相关联吗,从表中存储了相关借款单的扣款金额(Amount)

当对扣款单实现确认扣款的(批量)操作时,需要对这些扣款单下面所有下挂的借款单进行操作(选出的sql语句就是下面蓝色的语句2),当更新的金额如何跟当前对应的记录挂上勾的时候,就可以用下面的语句1进行关联了;注意的是语句1中的青色字体,可以获取被更新的表的列信息:OA_T_loaninfo.LoanId

update OA_T_loaninfo set ybxje=isnull(ybxje,0)+(
 select c.Amount from OA_ChargeBackDetail c where Loanid=OA_T_loaninfo.LoanId--(语句1)
 )  
 where loanid in (
 select b.LoanId from OA_ChargeBack a,OA_ChargeBackDetail b where a.guid in(@GuidStr) and b.id=a.ID  --(语句2)
 )

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值