使用:-- 下单时间超过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;