项目难点之下单(26.2)

下单过程需要锁定库存,同时需要锁定优惠券,而库存在product微服务模块,优惠券在coupon模块,涉及到分布式事务,但是通常情况下不能使用分布式事务:

扣减库存这一步可能出现的问题:

                   

 

 下单逻辑完整版,用来替代分布式事务:

 下单后创建订单(order表里面生成记录)扣减库存,

之后生成一个库存锁定记录,标注这个订单号关联的用户、商品以及买了几件,这部分信息会存储在mysql的表里面;同时会发送一个延迟消息到MQ 里面;

 创建订单、扣减库存后,会生成支付路径,等待用户支付,

// 下单记录表,coupon库中构建下单状时苏锁定优惠券的记录表
CREATE TABLE `coupon_task` (
`id` BIGINT(11) UNSIGNED NOT NULL
AUTO_INCREMENT,
`coupon_record_id` BIGINT(11) DEFAULT NULL COMMENT '优惠券记录id',
`create_time` DATETIME DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
`out_trade_no` VARCHAR(64) DEFAULT NULL COMMENT '订单号 XID',
`lock_state` VARCHAR(32) DEFAULT NULL COMMENT '锁定 LOCK- 完成FINISH 取消CANCEL',
PRIMARY KEY (`id`)
) ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4;

// 在商品product库中构建锁定库存的记录表

CREATE TABLE `product_task` (
`id` BIGINT(11) UNSIGNED NOT NULL AUTO_INCREMENT,
`product_id` BIGINT(11) DEFAULT NULL COMMENT '商品id',
`buy_num` INT(11) DEFAULT NULL COMMENT '购买数量',
`product_name` VARCHAR(128) DEFAULT NULL COMMENT '商品名称',
`lock_state` VARCHAR(32) DEFAULT NULL COMMENT '锁定LOCK 完成FINISH-取消CANCEL',
`out_trade_no` VARCHAR(32) DEFAULT NULL COMMENT '订单号XID',
`create_time` DATETIME DEFAULT CURRENT_TIMESTAMP,
PRIMARY KEY (`id`)
) ENGINE=INNODB AUTO_INCREMENT=1 DEFAULT CHARSET=utf8mb4;

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zero _s

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值