mysql批量条件修改记录

场景:

将b表的某些列值根据条件修改到a表中

sql如下:

UPDATE t_ucds_car_insure_test a
JOIN ( 
SELECT * FROM t_ucds_car_insure_middle
 ) b USING ( retail_total_order_num ) 
SET a.insurance_state = b.insurance_state,
a.sign_time = b.sign_time,
a.interest_state = b.interest_state,
a.interest_type = b.interest_type,
a.equity_package_content = b.equity_package_content,
a.operate_time = SYSDATE()
where a.on_line = 1;

解释:将b表的sign_time等列值修改到a表,将关联两表的条件放在USING中(a.retail_total_order_num  = b.retail_total_order_num ),将修改a表部分记录的条件放在where上(a.on_line=1的记录被修改,其他不符合条件的不修改,因为存在多个a.retail_total_order_num  是同一个值,但是on_line是不同的)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值