Java开源生鲜电商平台-团购模块设计与架构(源码可下载)
Java生鲜电商平台-团购模块设计与架构
说明:任何一个电商系统中,对于促销这块是必不可少的,毕竟这块是最吸引用户的,用户也是最爱的模块之一,理由很简单,便宜。
我的经验是无论是大的餐饮点还是小的餐饮店,优惠与折扣永远是说福他们进入平台的最好的手段之一。(大企业叫做节约成本,小企业叫做贪便宜.)
1.Java开源生鲜电商平台中,团购模块,我们采用以下几种维度思考。
1.1 针对的是生鲜中的标品。(米面粮油,我们要求买家可以自己发送团购,但是团购有次数,与时间以及买家起团金额和最低开团金额几个维度)
因此,需要有一个团购基础信息表:
CREATE TABLE `groups` (
`group_id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键',
`group_no` varchar(32) DEFAULT NULL COMMENT '团号',
`group_title` varchar(128) DEFAULT NULL COMMENT '团购标题',
`group_logo` varchar(128) DEFAULT NULL COMMENT '团购logo',
`group_area` varchar(128) DEFAULT NULL COMMENT '团购区域(区域ID集合)',
`begin_time` datetime DEFAULT NULL COMMENT '开始时间',
`end_time` datetime DEFAULT NULL COMMENT '结束时间',
`max_num` int(11) DEFAULT NULL COMMENT '最大买家数',
`buyer_amt` decimal(12,2) DEFAULT NULL COMMENT '买家起团金额',
`min_amt` decimal(12,2) DEFAULT NULL COMMENT '最低开团金额',
`group_status` tinyint(4) DEFAULT NULL COMMENT '状态(1发布 -1未发布 2团成 3未团成)',
`remarks` varchar(256) DEFAULT NULL,
`create_user_id` bigint(20) DEFAULT NULL COMMENT '创建人',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
PRIMARY KEY (`group_id`)
) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8 COMMENT='团购主表';
说明:这里面有一个团购的状态需要指明下,买家用户选择好几样商品后发起了团购,然后默认状态为-1,表示不可用,等组成了团购,最终状态会有团成的状态。
2. 对于团购而言,系统肯定需要记录,那些买家参与了那些团购,因此有以下的一张表记录
CREATE TABLE `groups_buyer` (
`gb_id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
`buyer_id` bigint(20) DEFAULT NULL COMMENT '买家ID',
`group_id` bigint(20) DEFAULT NULL COMMENT '团购ID',
`item_id` bigint(20) DEFAULT NULL COMMENT '团购明细ID',
`order_id` bigint(20) DEFAULT NULL COMMENT '订单ID',
`gb_num` int(11) DEFAULT NULL COMMENT '团购数量',
`gb_price` decimal(12,2) DEFAULT NULL COMMENT '团购价格',
`gb_amt` decimal(12,2) DEFAULT NULL COMMENT '团购金额',
`gb_status` tinyint(4) DEFAULT NULL COMMENT '状态(1完成 -1取消)',
`gb_time` datetime DEFAULT NULL COMMENT '团购时间',
PRIMARY KEY (`gb_id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8 COMMENT='团购买家表';
说明:团购买家表,记录那个买家,那个团购,团购的最终数量以及团购的价格等等,最终是否有买家在规定的时间内推出了团购,或者团购未形成等等。
3. 团购最终是对商品的规格进行团购。
谈谈商品的规格系数,我们知道蔬菜中有西红柿对吧,那么西红柿分为两种,一种是大红的,一种是粉红,这两种颜色都是西红柿,那么系统会认为这个是两个产品,而不是两个规格,规格到底是说的什么呢?
对于平台而言,规格就是一种商品的几种售卖方式。
最终根据业务分析,我们需要记录团购是由那些明细组成.(商品规格组成)
因此,最终系统架构如下:
CREATE TABLE `groups_item` (
`item_id` bigint(20) NOT NULL AUTO_INCREMENT COMMENT '主键ID',
`group_id` bigint(20) DEFAULT NULL COMMENT '团购ID',
`goods_id` bigint(20) DEFAULT NULL COMMENT '商品ID',
`format_id` bigint(20) DEFAULT NULL COMMENT '商品规格ID',
`group_price` decimal(12,2) DEFAULT NULL COMMENT '团购价格',
`group_num` int(11) DEFAULT NULL COMMENT '团购数量',
`item_status` tinyint(4) DEFAULT NULL COMMENT '状态(1在用 -1停用)',
`create_user_id` bigint(20) DEFAULT NULL COMMENT '创建人',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
PRIMARY KEY (`item_id`)
) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8 COMMENT='团购明细表';
业务总结:
1. 存在 一个买家发起的团购申请记录表。
2. 后端会有一个审核机制,默认1个小时内审核通过。
3. 团购会有商品的明细组成。也有时间段的范围与有消息。
4. 团购最终需要记录那些人参与了,然后交费完成等等。
补充说明:业务代码级别,无外乎提供给APP接口。以下几种功能:
1. 团购列表。
2. 团购明细。
3. 我的团购。
4,我的取消团购等
/**
* 团购Controller
*/
@RestController
@RequestMapping("/buyer")
public class GroupsController extends BaseController { private static final Logger logger = LoggerFactory.getLogger(GroupsController.class);
@Autowired
private GroupsService groupsService; /**
* 团购活动列表
* @param request
* @param response
*/
@RequestMapping(value = "/groups/list", method = { RequestMethod.GET})
public JsonResult groupsList(HttpServletRequest request, HttpServletResponse response,Long regionId) {
try{
if(null == regionId || 0 == regionId){
return new JsonResult(JsonResultCode.FAILURE, "参数错误,请检查regionId是否有传","");
}
List<GroupsVo> cgList = groupsService.getGroupsList(regionId);
return new JsonResult(JsonResultCode.SUCCESS, "查询信息成功", cgList);
}catch(Exception ex){
logger.error("[GroupsController][groupsList] exception :",ex);
return new JsonResult(JsonResultCode.FAILURE, "系统错误,请稍后重试","");
}
} /*
* 团购活动详情
*/
@RequestMapping(value = "/groups/detail", method = { RequestMethod.GET })
public JsonResult detailGroups(HttpServletRequest request, HttpServletResponse response,Long groupId) {
try{
if(null == groupId || 0 == groupId){
return new JsonResult(JsonResultCode.FAILURE, "参数错误,请检查groupId是否有传","");
}
GroupsVo groupsVo = groupsService.getGroupsInfo(groupId);
if(groupsVo == null){
groupsVo = new GroupsVo();
}
return new JsonResult(JsonResultCode.SUCCESS, "查询信息成功", groupsVo);
}catch(Exception ex){
logger.error("[GroupsController][detailGroups] exception :",ex);
return new JsonResult(JsonResultCode.FAILURE, "系统错误,请稍后重试","");
}
} /**
* 团购下单
* @param request
* @param response
*/
@RequestMapping(value = "/groups/createOrder", method = { RequestMethod.POST })
public JsonResult createOrder(HttpServletRequest request, HttpServletResponse response,
@RequestBody GroupOrder groupOrder) {
try {
String time = groupOrder.getBestTime();
if (StringUtils.isBlank(time)) {
return new JsonResult(JsonResultCode.FAILURE, "订单创建失败,收货时间不允许为空", "");
} OrderInfo addOrderInfo = groupsService.addOrderInfo(groupOrder);
if (addOrderInfo == null) {
return new JsonResult(JsonResultCode.FAILURE, "创建订单失败,订单金额小于起送价", "");
}
return new JsonResult(JsonResultCode.SUCCESS, "创建订单成功", addOrderInfo);
} catch (Exception ex) {
logger.error("[GroupsController][createOrder] exception :", ex);
return new JsonResult(JsonResultCode.FAILURE, "系统错误,请稍后重试", "");
}
}
}
总结:目前Java开源生鲜电商平台-团购模块设计与架构只是针对的是很普通的一些团购手段,当然对于拼多多而言,差距还是很大的。
这个也是跟业务形态有关,非技术有关,每一种促销方案并不是适合左右的买家用户或者说系统平台本身的。
由于时间关系或者说有关规定, APP运营截图相对而言比较简单,我这边就不贴出来了。
Java开源生鲜电商平台-团购模块设计与架构(源码可下载)的更多相关文章
- Java开源生鲜电商平台-用户表的设计(源码可下载)
Java开源生鲜电商平台-用户表的设计(源码可下载) 说明:由于该系统属于B2B平台,不设计到B2C的架构. 角色分析:买家与卖家. 由于买家与卖家所填写的资料都不一样,需要建立两站表进行维护,比如: ...
- Java开源生鲜电商平台-商品表的设计(源码可下载)
Java开源生鲜电商平台-商品表的设计(源码可下载) 任何一个电商,无论是B2C还是B2B的电商,商品表的设计关系到整个系统架构的核心. 1. 商品基本信息表:用单词:goods做为商品表 2. 商品 ...
- Java开源生鲜电商平台-订单表的设计(源码可下载)
Java开源生鲜电商平台-订单表的设计(源码可下载) 场景分析说明: 买家(餐馆)用户,通过APP进行选菜,放入购物车,然后下单,最终支付的流程,我们称为下单过程. 买家可以在张三家买茄子,李四家买萝 ...
- Java开源生鲜电商平台-财务系统模块的设计与架构(源码可下载)
Java开源生鲜电商平台-财务系统模块的设计与架构(源码可下载) 前言:任何一个平台也好,系统也好,挣钱养活团队这个是无可厚非的,那么对于一个生鲜B2B平台盈利模式( 查看:http://www.cn ...
- Java开源生鲜电商平台-支付模块的设计与架构(源码可下载)
Java开源生鲜电商平台-支付模块的设计与架构(源码可下载) 开源生鲜电商平台支付目前支持支付宝与微信.针对的是APP端(android or IOS) 1. 数据库表设计. 说明:无论是支付宝还 ...
- Java开源生鲜电商平台-系统简介
Java开源生鲜电商平台-系统简介 1.生鲜电商平台的价值与定位. 生鲜电商平台是一家致力于打造全国餐饮行业智能化.便利化.平台化与透明化服务的创新型移动互联网平台,连接买家与卖家之间的一个平台 看以 ...
- Java开源生鲜电商平台-系统架构与技术选型(源码可下载)
Java开源生鲜电商平台-系统架构与技术选型(源码可下载) 1. 硬件环境 公司服务器 2. 软件环境 2.1 操作系统 Linux CentOS 6.8系列 2.2 反向代理/web服务器 ...
- Java开源生鲜电商平台-盈利模式详解(源码可下载)
Java开源生鲜电商平台-盈利模式详解(源码可下载) 该平台提供一个联合买家与卖家的一个平台.(类似淘宝购物,这里指的是食材的购买.) 平台有以下的盈利模式:(类似的平台有美菜网,食材网等) 1. 订 ...
- Java开源生鲜电商平台-购物车模块的设计与架构(源码可下载)
ava开源生鲜电商平台-购物车模块的设计与架构(源码可下载) 说明:任何一个电商无论是B2C还是B2B都有一个购物车模块,其中最重要的原因就是客户需要的东西放在一起,形成一个购物清单,确认是否有问题, ...
随机推荐
- ubuntu11.04安装nginx+php+mysql
先列参考内容,后面我再补充点东西: http://www.4wei.cn/archives/1001436 http://www.gidot.net/blog/article.asp?id=322 上 ...
- RESTful规范建议
RESTful概述 RESTful是目前最流行的一种互联网软件架构.它结构清晰.符合标准.易于理解.扩展方便,所以正得到越来越多网站的采用. REST是Representational State T ...
- VueJs(11)---vue-router(进阶2)
vue-router(进阶2) 上篇文章讲了第一篇vue-router相关文章,文章地址:VueJs(10)---vue-router(进阶1) 一.命名路由 有时候,通过一个名称来标识一个路由显得更 ...
- NopCommerce是什么(转自CNSD)
NopCommerce是什么 nopCommerce--最好的免费购物车!nopCommerce是一个开源的解决方案.它是一个具有综合功能.对于新在线业务来说亦易于使用的解决方案,同时它也是一个功能强 ...
- 如何使用 toml 配置 SpaceVim
配置 SpaceVim 主要包括以下几个内容: 设置 SpaceVim 选项 启动/禁用模块 添加自定义插件 添加自定义按键映射以及插件配置 设置SpaceVim选项 原先,在 init.vim 文件 ...
- mysql 和 oracle 的一些小知识
有很多应用项目, 刚起步的时候用MYSQL数据库基本上能实现各种功能需求,随着应用用户的增多,数据量的增加,MYSQL渐渐地出现不堪重负的情况:连接很慢甚至宕机,于是就有把数据从MYSQL迁到ORAC ...
- 修改eclipse的workspace目录
打开Window,选择Preferences->General-->Startup and Shutdown->Workspaces,勾选Prompt for workspace o ...
- 2017年的golang、python、php、c++、c、java、Nodejs性能对比[续]
2017年的golang.python.php.c++.c.java.Nodejs性能对比[续] 最近忙,这个话题放了几天,今天来个续集. 上篇传送门: 2017年的golang.python.p ...
- Javascript中没有块级作用域(模仿)
在C/C++中,由花括号封闭的代码块都有自己的作用域,也就是块级作用域(私有作用域).而在javascript中则没有块级作用域,首先来看一段代码: function test(){ for(var ...
- 如何将数据库中存的树转化为树形列表(以easyui的tree为例)
很多时候,我们会把一棵树存放到数据库中,当前台需要展示一个树形列表时,将这棵树读取出来并显示,这个过程是怎么实现的呢? 这篇文章是以构造一棵easyui前台框架的一个树形列表为例,后台框架是sprin ...