## 优惠券
:-: ![](http://pic.qiantucdn.com/58pic/27/34/34/74458PICwIf_1024.jpg!/fw/580/watermark/url/L3dhdGVybWFyay12MS4zLnBuZw==/align/center)
优惠券,代金券,各种红包,积分,其实就是免费送给用户的财产,和用户余额没有本质区别(不能提现,只能消费,毕竟发放它就是为了刺激消费的),只不过有使用条件而已(比如满多少可用,不设找零,不退款等等),不能像余额那样提现。这些券之类的资产看似是免费补贴给用户的,其实都是一种营销,补贴就是营销的成本。
所以问题来了,这个成本谁出,商家还是平台。很简单,**当然是这个营销对谁有益,则由谁来承担。**
基于此,所以有一下规则:
平台优惠券,所有店铺可用;商家优惠券,商家发放,只在当前店铺消费时可用。
* * * * *
### 结算问题
**平台优惠券不参与结算**,所以商家并没有收到核销的优惠券来和平台抵扣的说法,比如订单实付100,用户使用平台优惠券抵扣了50,但是结算时还是看实付100的,并不会管这个抵扣的,商家还是要结算100走的。但是如果用户是使用的商家优惠券,那么结算时只能结算给商家50了,而不是实付的100,另外一种做法是,商家发放优惠券时就先把商家用于补贴的钱扣掉,比如商家往活动账户充值100,就可以发两张50的优惠券了。(这种方式商家发放优惠券需要先充值,一般在电商中不适用)
* * * * *
### 下单支付
#### 联合支付
shopnc采用,余额、线上联合支付的方式。比如订单实付100,余额只有50,那么扣50余额(下单,冻结余额为不可用,字段 `freeze_predeposit` ),剩下50由在线渠道支付。
联合支付方式,这也是最便捷的方式,即一个订单,可能由多部分共同组合支付完成,比如线上,余额,积分,白条,优惠券等等组合支付。(每个订单需要支付记录 `pay_order` 来记录这些)
这样虽然便捷,但是也有缺点,当退货,取消订单时的退款比较麻烦,当然优惠券是不能退款,这个在优惠券的规则里面有规定。
通常一个商家生成一个订单,平台优惠券是可以跨订单的,所以得平分到每个订单,当然并不是用 `除法` ,而是用 `减除法` 计算。否则可能有小数除不尽的情况。
~~~
余额支付和在线支付联合支付
先冻结余额部分,在线如果成功就扣,不成功那就要恢复余额。
~~~
#### 多笔订单合并支付
![这里也可以多选合并支付](http://cdn.aipin100.cn/18-3-30/92942662.jpg)
合并|2笔订单
![多订单提交直接合并支付](http://cdn.aipin100.cn/18-3-30/78936861.jpg)
(所以设计时还是要有一个支付订单表,`pay_order`:记录所有的发起的支付请求,为每个支付请求生成一个支付ID,通过`pay_order`与`order`以及其他业务关联,而不是直接用订单表来记录支付以及支付结果的回调)
* * * * *
#### 分期支付
白条支付额度不够,仅支付部分,剩下的可以选择银行卡支付。
银行卡支付 + 白条支付
![](http://cdn.aipin100.cn/18-4-3/50018462.jpg)
https://pcashier.jd.com/success/payResult.action?amount=347.37&orderType=0&passKey=A7A5CE9F16DBD6276FF64A1DC80AC8EB1875BC4368016D4FD084AE7517BE23D8&companyId=6&toType=10&cashierId=1&orderId=73794632808
* * * * *
### 转转的组合支付(高效灵活的支付)
1
![](http://cdn.aipin100.cn/18-3-4/2952719.jpg)
2
![](http://cdn.aipin100.cn/18-3-4/94250787.jpg)
3
![](http://cdn.aipin100.cn/18-3-4/86235073.jpg)
4
![](http://cdn.aipin100.cn/18-3-4/81259862.jpg)
5
![](http://cdn.aipin100.cn/18-3-4/59144510.jpg)
6
![](http://cdn.aipin100.cn/18-3-4/46499714.jpg)
7
![](http://cdn.aipin100.cn/18-3-4/81385444.jpg)
8
![](http://cdn.aipin100.cn/18-3-4/44675786.jpg)
* * * * *
### 扩展
[电商基本功:被小瞧的促销设计,并没有想得那么简单](http://toutiao.com/group/6527414499681501699/?iid=25315997380&app=news_article_lite×tamp=1519833724&wxshare_count=1&tt_from=weixin&utm_source=weixin&utm_medium=toutiao_android&utm_campaign=client_share)
![](http://cdn.aipin100.cn/6f22980e4740c709f5063f4a109f61ba)
> 很多人不明白商家为什么设置内部优惠券,而不直接在店铺里做优惠,可以看看
----
last update:2018-3-4 17:39:18
- 开始
- 公益
- 更好的使用看云
- 推荐书单
- 优秀资源整理
- 技术文章写作规范
- 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 接口自动化测试指南