在数据库中存储商店开启和关闭时间的最佳方法是什么,以及如何用PHP计算时间?
我想出了这个表设计:
+----+---------+----------+-----------+------------+
| id | shop_id | week_day | open_hour | close_hour |
+----+---------+----------+-----------+------------+
| 1 | 3 | 1 | 15:00:00 | 23:00:00 |
| 2 | 3 | 2 | 15:00:00 | 23:00:00 |
| 3 | 3 | 3 | 18:00:00 | 02:00:00 |
| 4 | 3 | 4 | 18:00:00 | 02:00:00 |
| 5 | 3 | 5 | 18:00:00 | 03:00:00 |
+----+---------+----------+-----------+------------+
+------------+---------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+------------+---------+------+-----+---------+----------------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| shop_id | int(11) | NO | | NULL | |
| week_day | int(11) | NO | | NULL | |
| open_hour | time | NO | | NULL | |
| close_hour | time | NO | | NULL | |
+------------+---------+------+-----+---------+----------------+
例如,在星期二(week_day = 2
),它在下午3点开放,在晚上11点(星期二)关闭。
星期三(“week_day = 2”),它在下午6点开放,在午夜凌晨2点结束,即周四。午夜之后应该保存在同一行吗?
假设客户希望在星期二晚上10点下订单(shop_id = 3
),他们应该能够根据数据库数据这样做。但是,如果客户希望在星期四凌晨1点订购,但数据库显示week_day = 3
关闭02:00:00
如果商店开放,如何用PHP编写工作?
我是否需要更改表格设计,以便用PHP编写更容易?
答案 0 :(得分:1)
答案 1 :(得分:0)
您可以说,如果close_hour小于open_hour,则给定条目的开放时间是第二天。
或者您可以使用单独的week_day列来打开和关闭时间。