81 lines
2.8 KiB
Markdown
81 lines
2.8 KiB
Markdown
|
|
---
|
||
|
|
title: A 流与 B 流
|
||
|
|
tags:
|
||
|
|
- prop-acc
|
||
|
|
- 一次性收费
|
||
|
|
- 核心概念
|
||
|
|
audience:
|
||
|
|
- 业户
|
||
|
|
- 业务人员
|
||
|
|
status: stable
|
||
|
|
last_reviewed: 2026-05-25
|
||
|
|
code_version: 2026-05-22
|
||
|
|
---
|
||
|
|
|
||
|
|
# A 流与 B 流
|
||
|
|
|
||
|
|
一次性收费支持两条独立购买路径,**底层用同一套数据表**,差别只在用户怎么发起。
|
||
|
|
|
||
|
|
## 一句话区别
|
||
|
|
|
||
|
|
> [!tip] 通俗版
|
||
|
|
> - **A 流**:您**到柜台**找物业阿姨,付了钱当场出货
|
||
|
|
> - **B 流**:您**自己在小程序**下单,微信付完,过来取(或者送到家)
|
||
|
|
|
||
|
|
## 对照表
|
||
|
|
|
||
|
|
| 维度 | A 流(线下即收即付) | B 流(线上订单—支付分离) |
|
||
|
|
|---|---|---|
|
||
|
|
| **典型用户** | 老人、不会用手机的业户 | 年轻业户、工作日没空到前台的人 |
|
||
|
|
| **触发动作** | 业户走到前台 | 小程序下单 |
|
||
|
|
| **付款时机** | 当场付(现金 / POS / 微信扫码) | 下单时锁定金额、付款分离 |
|
||
|
|
| **生效时机** | 即时 — 一笔操作完成所有 | 两步:下单 → 支付回调 |
|
||
|
|
| **失败模式** | 几乎不可能(人在柜台) | 可能超时未付、可能支付掉单 |
|
||
|
|
| **取消方式** | 走 [[场景-已收款作废\|作废]] 流程 | 改主意可主动撤;或超时自动作废 |
|
||
|
|
|
||
|
|
## 系统视角(流程图)
|
||
|
|
|
||
|
|
```mermaid
|
||
|
|
sequenceDiagram
|
||
|
|
participant 业户
|
||
|
|
participant 前台
|
||
|
|
participant 小程序
|
||
|
|
participant 系统
|
||
|
|
participant 支付网关
|
||
|
|
|
||
|
|
Note over 业户,系统: A 流(线下即收即付)
|
||
|
|
业户->>前台: 我要买 IC 卡
|
||
|
|
前台->>系统: 录入业户、项目、金额、付现金
|
||
|
|
系统->>系统: 一气呵成:建事件 + 建订单 + 建收据
|
||
|
|
系统-->>业户: 打印 / 微信收据立马拿到
|
||
|
|
|
||
|
|
Note over 业户,支付网关: B 流(订单—支付分离)
|
||
|
|
业户->>小程序: 下单 IC 卡
|
||
|
|
小程序->>系统: 建事件(Pending) + 建订单(Pending)
|
||
|
|
系统-->>业户: 锁价格、给您订单号
|
||
|
|
业户->>支付网关: 微信付款
|
||
|
|
支付网关->>系统: 支付回调
|
||
|
|
系统->>系统: 更新订单(Completed) + 自动出收据
|
||
|
|
系统-->>业户: 小程序通知:已付款,可来取货
|
||
|
|
```
|
||
|
|
|
||
|
|
## 为什么要两套?
|
||
|
|
|
||
|
|
> [!info] 业户视角
|
||
|
|
> - 老人不会用小程序 → A 流照顾他们
|
||
|
|
> - 年轻人不想跑前台 → B 流方便
|
||
|
|
> - **同一项业务两种付款方式都能用**
|
||
|
|
|
||
|
|
> [!info] 系统视角
|
||
|
|
> 两套**共用同一张 `AdHocEvent` 表 + 同一张 `CollectionOrder` 表**。差别只在:
|
||
|
|
> - A 流一气呵成创建后,状态直接 `Completed`
|
||
|
|
> - B 流先创建为 `Pending`,等支付回调才翻 `Completed`
|
||
|
|
>
|
||
|
|
> 这种设计的好处是**跨渠道补缴**天然支持 —— 详见 [[场景-跨渠道补缴]]。
|
||
|
|
|
||
|
|
## 看完去哪?
|
||
|
|
|
||
|
|
- 想了解购买后系统记了什么 → [[概念-CollectionOrder与Receipt]]
|
||
|
|
- 想了解订单的几种状态 → [[概念-AdHocEvent状态机]]
|
||
|
|
- 想看真实例子 → [[场景-A流-前台购买IC卡]] 或 [[场景-B流-小程序下单+微信支付]]
|