校园外卖系统和社会化外卖最大的不同,在于场景高度集中、时间高度重叠、规则相对固定。如果直接套用通用外卖模型,往往在高峰期会出现订单拥堵、配送混乱的问题。因此,在设计校园外卖系统小程序时,从下单到配送的业务逻辑必须更“克制”、更清晰。
下面我们从业务流程 → 数据模型 → 关键代码实现三个层面,拆解校园外卖系统的核心实现思路。
一、整体业务流程拆解
一个标准的校园外卖系统小程序,下单到完成配送,大致分为 6 个阶段:
- 用户选餐并提交订单
- 系统校验下单条件(时间、库存、配送范围)
- 商家接单并出餐
- 系统进入“待配送”状态
- 配送人员接单并完成配送
- 订单完成,进入结算与统计
在校园场景下,订单状态流转的稳定性,比复杂的营销玩法更重要。
二、核心数据模型设计
1. 订单表(order)
CREATETABLEorders(idBIGINTPRIMARYKEYAUTO_INCREMENT,user_idBIGINTNOTNULL,shop_idBIGINTNOTNULL,total_amountDECIMAL(10,2),statusVARCHAR(20),delivery_typeVARCHAR(20),created_atDATETIME,updated_atDATETIME);常见订单状态设计:
CREATED// 已下单PAID// 已支付ACCEPTED// 商家已接单PREPARING// 商家制作中WAIT_DELIVERY// 待配送DELIVERING// 配送中COMPLETED// 已完成CANCELLED// 已取消2. 订单商品表(order_item)
CREATE TABLE order_items (
id BIGINT PRIMARY KEY AUTO_INCREMENT,
order_id BIGINT,
goods_id BIGINT,
goods_name VARCHAR(100),
price DECIMAL(10,2),
quantity INT
);
三、小程序端:下单核心代码示例
1. 提交订单(小程序)
// submitOrder.jssubmitOrder(){constorderData={shopId:this.data.shopId,goodsList:this.data.cartList,deliveryType:'CAMPUS_DELIVERY'}wx.request({url:'/api/order/create',method:'POST',data:orderData,success:res=>{if(res.data.code===0){wx.navigateTo({url:`/pages/pay/index?orderId=${res.data.orderId}`})}}})}这里要注意两点:
不在小程序端计算最终金额(防止篡改)
所有价格以后台计算为准
四、后端:创建订单的核心逻辑
publicLongcreateOrder(CreateOrderDTOdto,LonguserId){// 1. 校验商家状态Shopshop=shopService.getById(dto.getShopId());if(!shop.isOpen()){thrownewBizException("商家未营业");}// 2. 计算订单金额BigDecimaltotalAmount=BigDecimal.ZERO;for(OrderGoodsDTOgoods:dto.getGoodsList()){totalAmount=totalAmount.add(goods.getPrice().multiply(BigDecimal.valueOf(goods.getQuantity())));}// 3. 创建订单Orderorder=newOrder();order.setUserId(userId);order.setShopId(dto.getShopId());order.setTotalAmount(totalAmount);order.setStatus("CREATED");orderMapper.insert(order);returnorder.getId();}在校园外卖系统中,下单接口一定要轻、快、可并发,复杂逻辑尽量拆到异步处理。
五、订单状态流转设计(核心)
校园外卖的稳定性,90% 取决于订单状态控制。
publicvoidupdateOrderStatus(LongorderId,StringtargetStatus){Orderorder=orderMapper.selectById(orderId);if(!OrderStatus.canTransfer(order.getStatus(),targetStatus)){thrownewBizException("非法状态流转");}order.setStatus(targetStatus);orderMapper.updateById(order);}状态流转校验示意:
CREATED->PAID PAID->ACCEPTED ACCEPTED->PREPARING PREPARING->WAIT_DELIVERY WAIT_DELIVERY->DELIVERING DELIVERING->COMPLETED这样可以有效避免:
- 重复接单
- 跳状态
- 高峰期并发导致的数据错乱
六、配送逻辑:校园场景的关键点
校园配送通常有两种模式:
- 商家自配送
- 校园骑手统一配送
配送接单示例
publicvoidacceptDelivery(LongorderId,LongriderId){Orderorder=orderMapper.selectById(orderId);if(!"WAIT_DELIVERY".equals(order.getStatus())){thrownewBizException("当前订单不可配送");}order.setStatus("DELIVERING");order.setRiderId(riderId);orderMapper.updateById(order);}在校园场景中,强制一单一骑手、限定配送范围,反而能提高整体效率。
七、高峰期的关键优化思路
在午餐、晚餐高峰期,校园外卖系统通常会:
限制同一用户短时间内重复下单
控制商家最大接单量
延迟非关键接口(如统计、消息推送)
例如简单的限流:
if(redis.incr("shop:order:count:"+shopId)>MAX_ORDER_LIMIT){thrownewBizException("当前下单人数较多,请稍后再试");}八、总结
校园外卖系统小程序的技术难点,不在于“功能多”,而在于业务链路是否足够清晰、状态是否可控、系统是否扛得住高峰。
从下单、接单、出餐到配送,每一步都要围绕“校园场景”去做取舍,而不是照搬通用外卖逻辑。