Java开源生鲜电商平台-优惠券设计与架构(源码可下载)
Java生鲜电商平台-优惠券设计与架构
说明:现在电商白热化的程度,无论是生鲜电商还是其他的电商等等,都会有促销的这个体系,目的就是增加订单量与知名度等等
那么对于Java开源生鲜电商平台而言,我们采用优惠券的这种方式进行促销。(补贴价格战对烧钱而言非常的恐怖的,太烧钱了)
1. 优惠券基础信息表
说明:任何一个优惠券或者说代金券都是有一个基础的说明,比如:优惠券名称,类型,价格,有效期,状态,说明等等基础信息。
CREATE TABLE `coupon` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '自动增加ID',
`region_id` bigint(20) DEFAULT NULL COMMENT '所属区域',
`type` int(11) DEFAULT NULL COMMENT '所属类型,1为满减',
`name` varchar(32) DEFAULT NULL COMMENT '优惠券名称',
`img` varchar(64) DEFAULT NULL COMMENT '图片的URL地址',
`start_time` datetime DEFAULT NULL COMMENT '优惠券开始时间',
`end_time` datetime DEFAULT NULL COMMENT '优惠券结束时间',
`money` decimal(11,2) DEFAULT NULL COMMENT '优惠券金额,用整数,固定值目前。',
`status` int(11) DEFAULT NULL COMMENT '状态,0表示未开始,1表示进行中,-1表示结束',
`remarks` varchar(512) DEFAULT NULL COMMENT '优惠券的说明',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
`full_money` decimal(12,2) DEFAULT NULL COMMENT '金额满',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='优惠券基础配置表';
说明:业务说可以规定某个区域,做优惠券,而且是纳新后才有,这样增加买家用户。价格可以后端进行设置。
状态的意义在于,用户需要注册完成后,然后主动认领才有效,为什么要这样设计呢?目的只有一个:让用户在对APP这个软件玩一会儿,增加熟悉程度.
2. 优惠券领取记录表
说明:我们需要记录那个买家,什么时候进行的领取,领取的的时间,券的额度是多少等等,是否已经使用等信息
CREATE TABLE `coupon_receive` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '自动增加ID',
`buyer_id` bigint(20) DEFAULT NULL COMMENT '买家ID',
`coupon_id` bigint(20) DEFAULT NULL COMMENT '优惠券编号',
`coupon_money` decimal(12,2) DEFAULT NULL COMMENT '券额',
`create_time` datetime DEFAULT NULL COMMENT '领取时间',
`full_money` decimal(12,2) DEFAULT NULL COMMENT '金额满',
`status` int(11) DEFAULT NULL COMMENT '状态,1为已使用,0为已领取未使用,-1为已过期',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='优惠券领取记录表';
3.优惠券消费记录表
说明:优惠券消费记录表,是需要知道那个买家,那个优惠券,那个订单使用了优惠券,这边有个特别注意的地方是,这个优惠券的执行在支付成功后的回调。
CREATE TABLE `coupon_logs` (
`id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '自动增加ID',
`buyer_id` bigint(20) DEFAULT NULL COMMENT '买家ID',
`coupon_receive_id` bigint(20) DEFAULT NULL COMMENT '优惠券id',
`order_number` varchar(64) DEFAULT NULL COMMENT '订单号',
`order_original_amount` decimal(12,2) DEFAULT NULL COMMENT '原订单金额',
`coupon_amount` decimal(11,2) DEFAULT NULL COMMENT '优惠券的金额',
`order_final_amount` decimal(12,2) DEFAULT NULL COMMENT '抵扣优惠券之后的订单金额',
`create_time` datetime DEFAULT NULL COMMENT '领取时间',
`status` int(2) DEFAULT '0' COMMENT '日志状态: 默认为0,支付回调成功后为1',
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='优惠券消费记录表';
说明:相对而言,优惠券的难度不算大,重点的是业务方面的指导与学习,包括数据库的架构与设计等等,还有就是思路的学习。
相关核心代码如下:
APP需要后台提供以下几个接口:
3.1 查询所有买家的优惠券。
3.2 判断买家是否可以领取优惠券。
3.3 买家主动领取优惠券
/**
* 优惠券controller
*/
@RestController
@RequestMapping("/buyer/coupon")
public class CouponController extends BaseController { private static final Logger logger = LoggerFactory.getLogger(CouponController.class); @Autowired
private CouponReceiveService couponReceiveService; @Autowired
private UsersService usersService; /**
* 查询买家所有优惠券
*
* @param request
* @param response
* @param buyerId
* @return
*/
@RequestMapping(value = "/list", method = { RequestMethod.GET, RequestMethod.POST })
public JsonResult getCouponList(HttpServletRequest request, HttpServletResponse response, Long buyerId) {
try {
if (buyerId == null) {
return new JsonResult(JsonResultCode.FAILURE, "买家不存在", "");
}
List<CouponReceive> result = couponReceiveService.selectAllByBuyerId(buyerId);
return new JsonResult(JsonResultCode.SUCCESS, "查询成功", result);
} catch (Exception ex) {
logger.error("[CouponController][getCouponList] exception", ex);
return new JsonResult(JsonResultCode.FAILURE, "系统错误,请稍后重试", "");
}
} /**
* 判断买家是否可以领取优惠券
*
* @param request
* @param response
* @param buyerId
* @return
*/
@RequestMapping(value = "/judge", method = { RequestMethod.GET, RequestMethod.POST })
public JsonResult judgeReceive(HttpServletRequest request, HttpServletResponse response, Long buyerId) {
try {
// 判断当前用户是否可用
Users users = usersService.getUsersById(buyerId);
if (users == null) {
logger.info("OrderController.judgeReceive.buyerId " + buyerId);
return new JsonResult(JsonResultCode.FAILURE, "你的账号有误,请重新登录", "");
}
int status = users.getStatus();
if (UserStatus.FORBIDDEN == status) {
return new JsonResult(JsonResultCode.FAILURE, "你的账号已经被禁用了,请联系公司客服", "");
}
List<Coupon> result = couponReceiveService.selectByBuyerId(buyerId);
if (CollectionUtils.isEmpty(result)) {
result = new ArrayList<Coupon>();
}
return new JsonResult(JsonResultCode.SUCCESS, "查询成功", result);
} catch (Exception ex) {
logger.error("[CouponController][judgeReceive] exception", ex);
return new JsonResult(JsonResultCode.FAILURE, "系统错误,请稍后重试", "");
}
} /**
* 买家领取优惠券
*
* @param request
* @param response
* @param buyerId
* @return
*/
@RequestMapping(value = "/add", method = { RequestMethod.GET, RequestMethod.POST })
public JsonResult saveCoupon(HttpServletRequest request, HttpServletResponse response, Long buyerId,
Long couponId) {
try {
// 判断当前用户是否可用
Users users = usersService.getUsersById(buyerId);
if (users == null) {
logger.info("OrderController.saveCoupon.buyerId " + buyerId);
return new JsonResult(JsonResultCode.FAILURE, "你的账号有误,请重新登录", "");
}
//判断当前用户的状态是否可用
int status = users.getStatus();
if (UserStatus.FORBIDDEN == status) {
return new JsonResult(JsonResultCode.FAILURE, "你的账号已经被禁用了,请联系公司客服", "");
}
if (couponId == null) {
return new JsonResult(JsonResultCode.SUCCESS, "活动已经结束", "");
}
//新增
int result = couponReceiveService.insert(buyerId, couponId);
if (result == -1) {
return new JsonResult(JsonResultCode.SUCCESS, "领取失败,已经领取过优惠券了", "");
} else if (result == 0) {
return new JsonResult(JsonResultCode.FAILURE, "领取失败,活动已经结束", "");
} else {
return new JsonResult(JsonResultCode.SUCCESS, "领取成功", "");
}
} catch (Exception ex) {
logger.error("[CouponController][saveCoupon] exception", ex);
return new JsonResult(JsonResultCode.FAILURE, "系统错误,请稍后重试", "");
}
}
}
最终总结:用户优惠券会发放在买家的APP中的个人中心里面,然后进行点击查看与领取,然后在支付的时候会自动显示出优惠券的数据,非常的灵活与方便。
Java开源生鲜电商平台-优惠券设计与架构(源码可下载)的更多相关文章
- Java开源生鲜电商平台-盈利模式详解(源码可下载)
Java开源生鲜电商平台-盈利模式详解(源码可下载) 该平台提供一个联合买家与卖家的一个平台.(类似淘宝购物,这里指的是食材的购买.) 平台有以下的盈利模式:(类似的平台有美菜网,食材网等) 1. 订 ...
- 点菜网---Java开源生鲜电商平台-商品基础业务架构设计-商品分类(源码可下载)
点菜网---Java开源生鲜电商平台-商品基础业务架构设计-商品分类 (源码可下载) 说明:我们搞过电商的人都可以体会到,搞生鲜电商是最复杂的,为什么复杂呢?我总结了有以下几个业务特性决定的: 1. ...
- Java开源生鲜电商平台-支付模块的设计与架构(源码可下载)
Java开源生鲜电商平台-支付模块的设计与架构(源码可下载) 开源生鲜电商平台支付目前支持支付宝与微信.针对的是APP端(android or IOS) 1. 数据库表设计. 说明:无论是支付宝还 ...
- Java开源生鲜电商平台-用户表的设计(源码可下载)
Java开源生鲜电商平台-用户表的设计(源码可下载) 说明:由于该系统属于B2B平台,不设计到B2C的架构. 角色分析:买家与卖家. 由于买家与卖家所填写的资料都不一样,需要建立两站表进行维护,比如: ...
- Java开源生鲜电商平台-商品表的设计(源码可下载)
Java开源生鲜电商平台-商品表的设计(源码可下载) 任何一个电商,无论是B2C还是B2B的电商,商品表的设计关系到整个系统架构的核心. 1. 商品基本信息表:用单词:goods做为商品表 2. 商品 ...
- Java开源生鲜电商平台-订单表的设计(源码可下载)
Java开源生鲜电商平台-订单表的设计(源码可下载) 场景分析说明: 买家(餐馆)用户,通过APP进行选菜,放入购物车,然后下单,最终支付的流程,我们称为下单过程. 买家可以在张三家买茄子,李四家买萝 ...
- Java开源生鲜电商平台-购物车模块的设计与架构(源码可下载)
ava开源生鲜电商平台-购物车模块的设计与架构(源码可下载) 说明:任何一个电商无论是B2C还是B2B都有一个购物车模块,其中最重要的原因就是客户需要的东西放在一起,形成一个购物清单,确认是否有问题, ...
- Java开源生鲜电商平台-推荐系统模块的设计与架构(源码可下载)
Java开源生鲜电商平台-推荐系统模块的设计与架构(源码可下载) 业务需求: 对于一个B2B的生鲜电商平台,对于买家而言,他需要更加快速的购买到自己的产品,跟自己的餐饮店不相关的东西,他是不关心的,而 ...
- Java开源生鲜电商平台-监控模块的设计与架构(源码可下载)
Java开源生鲜电商平台-监控模块的设计与架构(源码可下载) 说明:Java开源生鲜电商平台-监控模块的设计与架构,我们谈到监控,一般设计到两个方面的内容: 1. 服务器本身的监控.(比如:linux ...
随机推荐
- SqlServer中的事务隔离级别、锁机制
事务 作用:用来执行一连串的动作,并且保证所有动作要么都执行.要么都不执行. 属性:原子行.一致性.隔离性.持久性 锁 作用:SqlServer使用锁来实施事务隔离属性. 阻塞 定义:如果一个事务持有 ...
- Angularjs Post传值后台收不到的原因
如果你给AngularJS的post方法的data参数创一个key-value对象,那传给后台服务的就是JSON字符串,而正常的POST解析是需要像get?后面的那种&name=value这样 ...
- dp,px,pt,sp 的区别 以及dp 和 px 互转
dp = dip : device independent pixels(设备独立像素). 不同设备有不同的显示效果,这个和设备硬件有关,一般我们为了支持WVGA.HVGA和QVGA 推荐使用这个,不 ...
- nltk download失败
之前在台式机win10的系统,python 2.7,用的pycharm执行nltk download(),很顺利.然而到了我的笔记本只是换个一个win8的系统,Python的配置都是一样的,但是这时候 ...
- java运行机制、Jdk版本及Java环境变量
一.语言特性 计算机高级语言按程序的执行方式可分为:编译型和解释型两种.编译型的语言是指使用专门的编译器,针对特定的平台(操作系统)一次性翻译成被该平台硬件执行的机器码,并包装成该平台可执行性程序文件 ...
- Postgresql中临时表(temporary table)的特性和用法
熟悉Oracle的人,相比对临时表(temporary table)并不陌生,很多场景对解决问题起到不错的作用,开源库Postgresql中,也有临时表的概念,虽然和Oracle中临时表名字相同,使用 ...
- Cocos2d-x 实战
跨平台商业项目实战:攻城大作战游戏创意触发点:做什么样的游戏?分析当前主流的游戏:经典游戏(俄罗斯方块).大众化的游戏(卡牌游戏.休闲游戏).重口味游戏. 游戏创意:生活当中 游戏开发流程:1.策划方 ...
- Java动态代理(一)
好久没有动笔了,最近想巩固一下自己的基础知识,最近听到一同事问为什么JDK动态代理不能代理类,一听感觉懵逼呀!自己好像也不能很好的描述出来,所以想用2篇文章来复习一下动态代理知识: 一.什么是静态代理 ...
- 集群搭建(一)克隆虚拟机静态IP设置
[抛出问题] 当在搭建集群的时候,我们会将一个安装好相关程序的虚拟机进行克隆,克隆之后,我们会发下一些问题:就是原先的eth0 网卡不见了 原先的网卡 而克隆之后的网卡 会发现原来的网卡eth0 变为 ...
- QT5:C++实现基于Multimedia的音乐播放器(序)
前段时间C++课设,决定做个播放器,于是参考了网上的代码后,做了个很简陋的音乐播放器(只写了MP3格式)出来,虽然功能甚少,但还是决定把过程记录一下. 成品如下图: 播放器功能: 上.下一首,音量控制 ...