两种方案


两个分开事务过程

    通常是创建订单,再支付,这适用于在线支付(第三方在线支付),可以先创建订单,可以此后再选择订单去支付。


同一个事务内

    另一种直接扣余额的订单(不支持第三方在线支付),其实可以创建订单和支付用一步就可以,订单生成就意味着支付了,只有成功支付才会生成订单,下单和支付放在一个事物内了。


订单与支付

    一般情况下,请求一次支付会创建一个订单,如果没支付的订单就不显示而已,这是为了,让创建订单和支付像是一步一样,简化了流程,其实实际情况不是用户感知到这样的,只不过没支付的订单,没必要显示给用户而已。

    用户感知不到会创建订单,比如充值,购买会员等,用户感知不到这些操作会创建订单,但实际上是创建了订单的,这和商品订单有所不同。

    但是有时创建订单和支付也可以一步完成,比如只规定使用余额支付的订单,就可以创建订单和支付为一步原子操作。