首页 > 新人求教关于拼车系统的设计问题

新人求教关于拼车系统的设计问题

初来乍到,表达能力也一般,还望各位多包含、多指教
这个系统跟传统的拼车有所区别,是根据我们这边的一些私营车队(类似汽车站线路车)作为参照物来思考的
系统的功能大致如下:
1、订单
2、线路(某城市至某城市,往返)
3、车队(类似用户组,归类属于某城市至某城市线路的司机,并排序)
4、司机

根据自己观察后思考所得的业务需求应该如下:
1、用户下单至系统,数据包含出发城市、目的城市、人数、出发时间
2、系统按照如下条件完成分配:
2.1、根据用户的出发地和目的地匹配到属于该线路的车队
2.2、根据用户的出发地匹配到该车队内目前在当前城市的司机(按照车队内司机的先后顺序)
2.3、检索已分配给该司机的订单,并统计其订单内人数总和是否大于4,假设当前司机已存在系统分配订单的人数总和已经达到3人,而当前新订单的人数是2人,总和大于4,则将该新订单自动分配给下一位司机
2.4、满足以上条件后将该司机置于发车状态

目前打算将车队及车队内司机用以下格式做redis缓存

array(
    array(
        'name' => '车队1',
        'route' => '1,2', // 线路所属的两个城市的id,用这种格式比较好判断
        'members' => array(
            array('司机1', '电话', 序号, 所在城市id, ...),
            array('司机2', '电话', 序号, 所在城市id, ...),
            array('司机3', '电话', 序号, 所在城市id, ...)
        )
    ),
    array(
        'name' => '车队2',
        'route' => '3,4', // 线路所属的两个城市的id,用这种格式比较好判断
        'members' => array(
            array('司机1', '电话', 序号, 所在城市id, ...),
            array('司机2', '电话', 序号, 所在城市id, ...),
            array('司机3', '电话', 序号, 所在城市id, ...)
        )
    )
    ...
);

以上都是我自己思考而来,起初只是为了测试自己的程度,但是现在还没走多远就卡在了订单分配这个环节,求大神指点一二,程序上也好,数据库设计上的也好,非常感谢。


派单这个业务,你怎么实现都没问题,逻辑完整就好了。
手工分配,司机抢单,或者是你自己想的自动分配都可以啊,按照实际需要来实现就好了。
如果觉得哪里想不太清楚,你就画个流程图看看。

【热门文章】
【热门文章】