欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  后端开发

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

程序员文章站 2022-05-01 12:58:29
...
初来乍到,表达能力也一般,还望各位多包含、多指教
这个系统跟传统的拼车有所区别,是根据我们这边的一些私营车队(类似汽车站线路车)作为参照物来思考的
系统的功能大致如下:
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, ...)
        )
    )
    ...
);

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

回复内容:

初来乍到,表达能力也一般,还望各位多包含、多指教
这个系统跟传统的拼车有所区别,是根据我们这边的一些私营车队(类似汽车站线路车)作为参照物来思考的
系统的功能大致如下:
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, ...)
        )
    )
    ...
);

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

相关标签: mysql php