新人求教关于拼车系统的设计问题
这个系统跟传统的拼车有所区别,是根据我们这边的一些私营车队(类似汽车站线路车)作为参照物来思考的
系统的功能大致如下:
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, ...)
)
)
...
);
以上都是我自己思考而来,起初只是为了测试自己的程度,但是现在还没走多远就卡在了订单分配这个环节,求大神指点一二,程序上也好,数据库设计上的也好,非常感谢。