Java生鮮電商平臺-推薦系統模塊的設計與架構git
業務需求:github
對於一個B2B的生鮮電商平臺,對於買家而言,他須要更加快速的購買到本身的產品,跟本身的餐飲店不相關的東西,他是不關心的,並且過多無用的東西摻雜在一塊兒,反而不便算法
於買家下單,用戶體驗也不好,嚴重的會所以丟了客戶。(客戶以爲太難用了。通常都就會放棄使用.)spring
對於賣家而言,他本身就調整下本身的商品的上架與下架,而後就是調整下本身商品的價格。(蔬菜類的商品會隨着市場的供求關係會有相應的波動.)數據庫
業務分析:架構
推薦系統:根據買家的行爲習慣以及購買行爲來推薦些他可能須要的東西的一套算法系統。app
對於買家而言,數量來源於如下三個維度:異步
1. 購買記錄。-----買家實際下的訂單。post
2. 收藏夾。 -----對於買家而言,收藏了某個商品,可是並沒購買的,咱們認爲他也會購買,屬於須要推送的數據之一。this
3. 經常使用清單。----用戶最近一段時間購買的記錄,咱們業務分析認爲他必定會再次購買,由於相對一個餐館而言,它所作的菜從某種程度來講是必定的,因此購買的食材,也相對而言也是相似的。也就是說昨天買的,今天可能也會再次夠買,只是數量有所變化而言。
4. 同類推薦。 ----對於一個餐館而言,好比說小炒相似的餐館,那麼不少相似小炒的餐館的全部菜應該也是相似的,也許存在不須要的,可是也存在可能須要的狀況,也屬於咱們的推薦系統中的。
5. 系統推薦。 ----對於一個剛註冊的買家而言,咱們但願給他更好的業務體驗,那麼在註冊的時候,他就會必定選擇一個所屬類別,根據類別,咱們會把相應的類別的系統清單推薦出來,讓客戶一進來就感受到這些他所須要的菜都好像是系統跟他量身定作的同樣。
根據以上的業務分析,咱們理清楚了上述的全部維度,如下是數據庫的設計與思路:
1. 購買記錄。來源於訂單明細記錄表:
CREATE TABLE `order_item` ( `item_id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '主鍵', `order_id` bigint(20) DEFAULT NULL COMMENT '訂單主表id,order_info表的order_id', `order_number` varchar(32) DEFAULT NULL COMMENT '惟一訂單號', `order_status` tinyint(4) DEFAULT NULL COMMENT '訂單項狀態,1爲已提交訂單,2爲取消訂單', `format_id` bigint(20) DEFAULT NULL COMMENT '商品規格的ID', `buyer_id` bigint(20) unsigned DEFAULT '0' COMMENT '買家ID', `seller_id` bigint(20) DEFAULT NULL COMMENT '所屬賣家ID', `delivery_type` tinyint(2) DEFAULT '1' COMMENT '配送類型,1爲平臺送,2.賣家本身送', `delivery_status` tinyint(2) DEFAULT '0' COMMENT '配送狀態,0 表示未收貨,1表示已收貨,送貨中,2表示已收貨,已送貨', `seller_status` tinyint(4) DEFAULT '0' COMMENT '賣家備貨狀態,0爲備貨中,1爲備貨完成,2爲缺貨', `buyer_status` tinyint(2) unsigned DEFAULT '0' COMMENT '買家狀態,0待收貨,1爲已收貨,2爲換貨,3爲退貨', `remark` varchar(255) DEFAULT NULL COMMENT '訂單項備註,由用戶提交訂單前填寫', `goods_number_old` decimal(12,2) DEFAULT NULL COMMENT '訂單初始商品數量', `goods_number` decimal(12,2) DEFAULT NULL COMMENT '商品的數量', `goods_price` decimal(12,2) DEFAULT NULL COMMENT '商品的單價', `goods_amount` decimal(12,2) DEFAULT NULL COMMENT '單項總金額', `delivery_money` decimal(12,2) DEFAULT '0.00' COMMENT '配送費用', `create_time` datetime DEFAULT NULL COMMENT '訂單建立時間', `delivery_receive_time` datetime DEFAULT NULL COMMENT '配送人員收貨時間', `delivery_finish_time` datetime DEFAULT NULL COMMENT '配送人員完成時間', `seller_finish_time` datetime DEFAULT NULL COMMENT '賣家完成時間', `buyer_finish_time` datetime DEFAULT NULL COMMENT '買家完成時間', `method_id` bigint(20) DEFAULT NULL COMMENT '加工方式ID', `delivery_id` bigint(20) DEFAULT NULL, PRIMARY KEY (`item_id`) ) ENGINE=InnoDB AUTO_INCREMENT=3424 DEFAULT CHARSET=utf8 COMMENT='訂單的子項目';
2. 收藏夾系統數據庫表:
說明:收藏夾比較簡單,某個商品ID,那個買家,何時收藏的。
3. 經常使用清單
說明:經常使用清單,維度也是對於商品而言,不是針對某一個店鋪,由於咱們市場反饋給出的結論是買家關注的商品自己,而不是那個賣家。
4. 同類分析。
說明:數據來源於相似的餐館點。咱們把餐館店分爲幾種類型,在地推團隊來銷售產品的時候,實際上是知道那個餐館的所屬類別的。
(客戶的類型,1爲火鍋店,2爲小餐館,3爲中餐館,4,爲燒烤)
5. 系統推薦。
說明:系統推薦,跟收藏夾,買家經常使用清單功能都很相似,不一樣點就在於業務的範圍與範疇。
剛註冊的用戶的經常使用清單的數據就來源於系統推薦的數據。
相關業務核心代碼以下:
1.註冊代碼中添加
/** * 買家註冊,第二步完善資料 * @param request * @param response * @return */ @RequestMapping(value = "/register/second/step", method = { RequestMethod.GET, RequestMethod.POST }) public JsonResult secondStepRegister(HttpServletRequest request, HttpServletResponse response,@RequestBody Buyer buyer) { logger.info("UsersController.secondStepRegister.seller:新增買家:" + buyer); if (buyer == null) { return new JsonResult(JsonResultCode.FAILURE, "參數異常", ""); } try { buyerService.updateBuyer(buyer); //添加買家默認的經常使用清單 buyerService.insertBuyerCommon(buyer.getBuyerId(), buyer.getBuyerType(), buyer.getRegionId()); return new JsonResult(JsonResultCode.SUCCESS, "完善買家信息成功",buyer); } catch (Exception e) { logger.error("[UsersController][secondStepRegister] exception :", e); return new JsonResult(JsonResultCode.FAILURE, "系統錯誤,請稍後重試", ""); } }
2.經常使用清單方面
/** * 個人經常使用清單 */ @RequestMapping(value = "/my/commonList", method = { RequestMethod.GET, RequestMethod.POST }) public JsonResult commonList(HttpServletRequest request, HttpServletResponse response, Long userId) { try { List<CommonListVo> list = buyerService.getCommonList(userId); return new JsonResult(JsonResultCode.SUCCESS, "查詢信息成功", list); } catch (Exception ex) { logger.error("[MyController][commonList] exception :", ex); return new JsonResult(JsonResultCode.FAILURE, "系統錯誤,請稍後重試", ""); } }
3。系統經常使用清單
說明:系統經常使用清單來源於後臺管理人員人工添加
相應代碼以下;
/** * 到新增頁面; */ @RequestMapping(value = "/toAdd", method = { RequestMethod.GET, RequestMethod.POST }) public String toAdd(HttpServletRequest request, HttpServletResponse response, Model model, SysCommonVo sysCommonVo,@ModelAttribute SearchGoodsVo sgv) { // 獲取分頁當前的頁碼 int currentPageNum = this.getPageNum(request); // 獲取分頁的大小 int currentPageSize = this.getPageSize(request); //區域ID Long areaId = sysCommonVo.getAreaId(); sgv.setAreaId(areaId); sgv.setSearchStatus((short) 1); sgv.setFormatStatus((short)1); sgv.setSellerStatus((short)3); List<SysCommonVo> sysCommon = sysCommonService.getSysCommon(sysCommonVo); StringBuffer sb = new StringBuffer(); if(sysCommon.size()>0){ for (int i = 0; i < sysCommon.size(); i++) { if(i != sysCommon.size()-1){ SysCommonVo sc = sysCommon.get(i); sb.append(sc.getGoodsId()); sb.append(","); }else { SysCommonVo sc = sysCommon.get(i); sb.append(sc.getGoodsId()); } } } sgv.setGoodIds(new String(sb)); PageUtil paginator = goodsService.getPageResultByCommon(sgv, currentPageNum, currentPageSize); model.addAttribute("paginator", paginator); model.addAttribute("sgv", sgv); model.addAttribute("sysCommonVo", sysCommonVo); return "sys/common/addFrom"; }
說明:相對而言,這個代碼都是強依賴於數據庫,畢竟不可能不少時間都有人同時買菜與註冊。不少時候都是聯表查詢便可完成數據的分析與統計。
5.定時器代碼。(數據的系統推薦與個性化推薦都是系統採用定時器進行處理的。spring task)
相關代碼以下;
總結:全部的推薦系統的模型都相似我上面來的幾個維度的思考,須要根據本身的業務實際狀況,本身分析與總結,至因而同步仍是異步,仍是定時器等等都是處理手段,
我這邊就採用了,同步與異步,包括定時器同時計算的過程,最終達到用戶的推薦效果。
Java開源生鮮電商平臺-推薦系統模塊的設計與架構(源碼可下載),若是須要下載的話,能夠在個人github下面進行下載。
相應的業務實際運行圖以下: