php预约功能的时间和数据库的架构问题!-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

php预约功能的时间和数据库的架构问题!

小旋风柴进 2016-03-06 16:52:54 2425

PHP实现某位医生的预约, 必须提前一天预约 今天凌晨24点前只能预约第二天上午10:00-21:00的医生.
假如预约了医生A 明天的10点,那么这个医生明天10点11点都不能再预约 这个怎么实现?拜托了各位前辈,小弟刚实习好不容易找到个工作 遇到这样的问题 希望各位能帮忙下

PHP 数据库
分享到
取消 提交回答
全部回答(1)
  • 小旋风柴进
    2019-07-17 18:54:52

    按你上面说的,被预约时长一个小时
    最简单的,那只要记录被预约的时刻,如
    医生id | 日期 | 时刻 | 预约人
    1 20150508 10 a1
    1 20150508 13 a2
    1 20150508 14 a3
    1 20150508 16 a4

    这个时候 a5 来了 想预约15时,只要查询 "select * from [预约表] where 日期=20150508 and 时刻=15 and 医生=1",如果存在记录说明被预约了

    同样的,如果任务时长为 n 小时,只要把一天分成 m 个 n 小时时长的段,并编号,就可以按上面的做法。

    如果更高级一点,可以内存中存一个矩阵,一个医生按上面的思路,行为医生、列为时间编号,被预约置1,然后查询对应点是否为0,为0即有空。

    当然,还有更复杂的调度算法,不过,我没有接触,但想来上面这个思路应该就够用了

    0 0
数据库
使用钉钉扫一扫加入圈子
+ 订阅

分享数据库前沿,解构实战干货,推动数据库技术变革

推荐文章
相似问题
推荐课程