## 訂單與支付設計
**last update: 2022-06-06 10:23:11**
----
[TOC=3,8]
----
### 支付與訂單的
#### 生命周期
1. 訂單創建,待支付(支付單創建)
... 支付回執來了
2. 支付單 達成 [支付確認 pay_ack]
3. 業務單 達成 [支付確認 pay_ack]
4. 業務單 履行業務職責(如果有業務職責邏輯的話)
5. 業務單 如果履行業務職責 失敗,那么 ~~要針對 此 支付單進行退款~~ 可以進行補單(重新履行業務)
6. 業務單 如果成功履行了,那么訂單交易完成的邏輯就執行了,如處理充值到賬
----
#### 業務的冪等性
1. 支付單/業務單 [支付確認 pay_ack] 只能達成一次
,即業務履行必須只能一次
2. 退款是針對 支付單 一對一的,~~一個支付單只能創建一次退款單(退款記錄)~~ 可以退款多次(總退款金額不超過訂單交易金額)
----
#### 支付單與業務訂單的關系
1. 組合支付單表示 業務單最終的 [支付確認 pay_ack] 可能由多個支付單共同達成
2. 業務單的 每個不同 支付渠道/金額 對應一個 支付單
3. 支付單 直面第三方支付(流水號即為商戶訂單號),業務單 與 支付單 是 可能一對多的
----
### 表重要字段
```
業務訂單表:
status: 訂單狀態:0-創建,1-已取消,2-交易失敗,3-交易完成
pay_status: 支付狀態:0-待支付,1-已支付,2-已取消支付(訂單取消/關閉時 標記為取消支付)
is_there_refund: 訂單是否有退款記錄(注意不一定有退款記錄就表示此訂單無效)
amount: 應付金額
(交易金額)
```
```
支付單(流水)表
pay_status: 支付狀態:0-待支付,1-已支付,2-已取消支付(訂單取消/關閉時 標記為取消支付)
is_compose: 是否為組合支付訂單
is_there_refund: 訂單是否有退款記錄(注意不一定有退款記錄就表示此訂單無效)
order_id: 業務單id
amount: 應付金額
```
```
退款記錄表
flowing_id: 支付單id
desc: 退款說明原因
```
注意:
1. 如果系統提供 “標記為已支付” 這樣的功能,那么這個操作 只能更改業務訂單表,不能更新支付單表,否則回執時 對支付單支付狀態檢查時,我們不知道是否為渠道重試了
2. 對于 業務單,系統其他后臺功能 “標記為已支付” 等功可能會更新其支付狀態
3. 對于 支付單,pay_status 是否 達成了 [支付確認 pay_ack] (達成 是由用戶完成支付后渠道回執來的)
----
### 收到回執時,如何區分重試和重復支付
#### 有支付單的設計:
1. 發現 支付單 已經達成 [支付確認 pay_ack] 就為重試
2. 發現 業務單 已經達成 [支付確認 pay_ack] 就為重復支付(可能是由于舊支付單,如砍價造成的,或者是多渠道重復支付了)
#### 沒有支付單設計的:
1. [支付確認 pay_ack] 達成時 記錄下對應的渠道
2. 收到回執時判斷達成的渠道是否為當前渠道
3. 是 即為重試,否就為其它渠道重復支付,應該安排退款。
----
### 擴展
[聊聊對賬系統的設計方案](https://mp.weixin.qq.com/s/47s0YdRM6u1JNngNe6yghg)(樓下小黑哥)
[聊聊對賬系統的設計方案 - 知乎](https://zhuanlan.zhihu.com/p/55573709)(樓下小黑哥)
[支付對賬系統怎么設計?](https://mp.weixin.qq.com/s?__biz=MzU3NDY4NzQwNQ==&mid=2247483860&idx=1&sn=e5b8a68b7ede74dae33e60fa69ddedca&scene=21#wechat_redirect)(無敵碼農)
[咱們聊聊對賬系統該如何設計](https://juejin.cn/post/6844903618680733704)(AskHarries - 掘金)
> 廣義的對賬,所有跨應用的數據交互,理論上都應該進行對賬。所以對賬也**可以分為信息流對賬,資金流對賬。信息流對賬也一般用在自己內部系統的對賬**,比如支付系統的**支付數據和業務系統的業務數據進行對賬,保證資金交易和業務交易的一致性**。資金流對賬也就是支付系統和銀行或者第三方支付系統之間的資金交易對賬。
[對賬處理 - Cocolian Framework | 可可鏈](http://doc.cocolian.cn/essay/recon/2016/10/10/account-2-reconciliation/)(鳳凰老熊)
[移動端支付系統如何設計有效地防重失效機制?](https://mp.weixin.qq.com/s?__biz=MzU3NDY4NzQwNQ==&mid=2247483673&idx=1&sn=abc81adf43f999f9ba535721a73de702&chksm=fd2fd0dbca5859cd7a90e09e6b4a3af7b5e8a8a89b09fbaf73f987d4def3a5cfe6f33c4c161d&scene=21#wechat_redirect)(無敵碼農)
[## 鎖住余額,為何還會更新異常?](https://mp.weixin.qq.com/s?__biz=MzIzMTgwODgyMw==&mid=2247483935&idx=1&sn=176c01be1a220071e78d60e6d295c34e&chksm=e89fc847dfe841515bf8901ec7ee7ca3102731cdb475275093f2d07ac9a6bb10d54ce37beed9&scene=178&cur_album_id=1337216649245655040#rd)(樓下小黑哥)
[Redis 分布式鎖使用不當,釀成一個重大事故,超賣了100瓶飛天茅臺!!!](https://mp.weixin.qq.com/s/oQKK83Syi29JLzWkEM0P2g)
[財務對賬系統 | 人人都是產品經理](http://www.woshipm.com/tag/%E8%B4%A2%E5%8A%A1%E5%AF%B9%E8%B4%A6%E7%B3%BB%E7%BB%9F)
-----
- 開始
- 公益
- 更好的使用看云
- 推薦書單
- 優秀資源整理
- 技術文章寫作規范
- SublimeText - 編碼利器
- PSR-0/PSR-4命名標準
- php的多進程實驗分析
- 高級PHP
- 進程
- 信號
- 事件
- IO模型
- 同步、異步
- socket
- Swoole
- PHP擴展
- Composer
- easyswoole
- php多線程
- 守護程序
- 文件鎖
- s-socket
- aphp
- 隊列&并發
- 隊列
- 講個故事
- 如何最大效率的問題
- 訪問式的web服務(一)
- 訪問式的web服務(二)
- 請求
- 瀏覽器訪問阻塞問題
- Swoole
- 你必須理解的計算機核心概念 - 碼農翻身
- CPU阿甘 - 碼農翻身
- 異步通知,那我要怎么通知你啊?
- 實時操作系統
- 深入實時 Linux
- Redis 實現隊列
- redis與隊列
- 定時-時鐘-阻塞
- 計算機的生命
- 多進程/多線程
- 進程通信
- 拜占庭將軍問題深入探討
- JAVA CAS原理深度分析
- 隊列的思考
- 走進并發的世界
- 鎖
- 事務筆記
- 并發問題帶來的后果
- 為什么說樂觀鎖是安全的
- 內存鎖與內存事務 - 劉小兵2014
- 加鎖還是不加鎖,這是一個問題 - 碼農翻身
- 編程世界的那把鎖 - 碼農翻身
- 如何保證萬無一失
- 傳統事務與柔性事務
- 大白話搞懂什么是同步/異步/阻塞/非阻塞
- redis實現鎖
- 淺談mysql事務
- PHP異常
- php錯誤
- 文件加載
- 路由與偽靜態
- URL模式之分析
- 字符串處理
- 正則表達式
- 數組合并與+
- 文件上傳
- 常用驗證與過濾
- 記錄
- 趣圖
- foreach需要注意的問題
- Discuz!筆記
- 程序設計思維
- 抽象與具體
- 配置
- 關于如何學習的思考
- 編程思維
- 談編程
- 如何安全的修改對象
- 臨時
- 臨時筆記
- 透過問題看本質
- 程序后門
- 邊界檢查
- session
- 安全
- 王垠
- 第三方數據接口
- 驗證碼問題
- 還是少不了虛擬機
- 程序員如何談戀愛
- 程序員為什么要一直改BUG,為什么不能一次性把代碼寫好?
- 碎碎念
- 算法
- 實用代碼
- 相對私密與絕對私密
- 學習目標
- 隨記
- 編程小知識
- foo
- 落盤
- URL編碼的思考
- 字符編碼
- Elasticsearch
- TCP-IP協議
- 碎碎念2
- Grafana
- EFK、ELK
- RPC
- 依賴注入
- 科目一
- 開發筆記
- 經緯度格式轉換
- php時區問題
- 解決本地開發時調用遠程AIP跨域問題
- 后期靜態綁定
- 談tp的跳轉提示頁面
- 無限分類問題
- 生成微縮圖
- MVC名詞
- MVC架構
- 也許模塊不是唯一的答案
- 哈希算法
- 開發后臺
- 軟件設計架構
- mysql表字段設計
- 上傳表如何設計
- 二開心得
- awesomes-tables
- 安全的代碼部署
- 微信開發筆記
- 賬戶授權相關
- 小程序獲取是否關注其公眾號
- 支付相關
- 提交訂單
- 微信支付筆記
- 支付接口筆記
- 支付中心開發
- 下單與支付
- 支付流程設計
- 訂單與支付設計
- 敏感操作驗證
- 排序設計
- 代碼的運行環境
- 搜索關鍵字的顯示處理
- 接口異步更新ip信息
- 圖片處理
- 項目搭建
- 閱讀文檔的新方式
- mysql_insert_id并發問題思考
- 行鎖注意事項
- 細節注意
- 如何處理用戶的輸入
- 不可見的字符
- 抽獎
- 時間處理
- 應用開發實戰
- python 學習記錄
- Scrapy 教程
- Playwright 教程
- stealth.min.js
- Selenium 教程
- requests 教程
- pyautogui 教程
- Flask 教程
- PyInstaller 教程
- 蜘蛛
- python 文檔相似度驗證
- thinkphp5.0數據庫與模型的研究
- workerman進程管理
- workerman網絡分析
- java學習記錄
- docker
- 筆記
- kubernetes
- Kubernetes
- PaddlePaddle
- composer
- oneinstack
- 人工智能 AI
- 京東
- pc_detailpage_wareBusiness
- doc
- 電商網站設計
- iwebshop
- 商品規格分析
- 商品屬性分析
- tpshop
- 商品規格分析
- 商品屬性分析
- 電商表設計
- 設計記錄
- 優惠券
- 生成唯一訂單號
- 購物車技術
- 分類與類型
- 微信登錄與綁定
- 京東到家庫存系統架構設計
- crmeb
- 命名規范
- Nginx https配置
- 關于人工智能
- 從人的思考方式到二叉樹
- 架構
- 今日有感
- 文章保存
- 安全背后: 瀏覽器是如何校驗證書的
- 避不開的分布式事務
- devops自動化運維、部署、測試的最后一公里 —— ApiFox 云時代的接口管理工具
- 找到自己今生要做的事
- 自動化生活
- 開源與漿果
- Apifox: API 接口自動化測試指南