mysql 自关联更新_MySQL UPDATE关联更新多表

该篇博客介绍了如何通过SQL更新操作自动处理超过24小时未支付的订单,将其状态设置为已取消,并将库存回滚。涉及订单表、订单详细表和产品规格表的数据更新,同时记录取消原因和类型。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用:-- 下单时间超过24小时,自动取消订单,归还对应规格库存数量

-- 订单表、订单详细表、产品规格表

UPDATE m_ufmall_order muo,m_ufmall_order_detail muod,m_ufmall_product_norms mupn SET

-- 非体检订单状态,如果 order_state=1(待付款)返回 0 取消状态。否则返回原order_state

muo.order_state = IF(muo.order_state=1,0,muo.order_state),

-- 体检订单状态,如果 tjyy_state=1000(待付款)返回 4002 取消状态。否则返回原order_state

muo.tjyy_state = IF(muo.tjyy_state=1000,4002,muo.tjyy_state),

-- 取消备注信息

muo.order_remake ='超时未支付取消',muo.cancel_type = 'auto',

-- 库存归还

mupn.stock = (mupn.stock + muo.order_num)

-- 订单号

WHERE muo.order_code = muod.order_code

-- 产品规格ID

AND muod.norm_id = mupn.id

-- 产品ID

AND muod.product_id = mupn.product_id

-- 普通或者体检 未支付

AND (muo.order_state = 1 OR muo.tjyy_state = 1000)

-- 超时

AND TIMESTAMPDIFF(SECOND,muo.order_time,NOW()) >= 86400

语法:--

UPDATE A INNER JOIN B ON A.xx = B.xx AND A.yy = B.yy SET A.cc = B.cc;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值