在数据库中存储商店开放和关闭时间的最佳方法是什么,以及如何计算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点结束,即周四.午夜(00:00:00或之后)关闭时间应该如何存储在数据库中?
假设客户希望在星期二晚上10点下订单(shop_id = 3),他们应该能够根据数据库数据这样做.但是,如果客户希望在星期四凌晨1点订购,但数据库显示的是week_day = 3,那么它将在02:00:00关闭
如果商店开放,如何用PHP编写工作?看起来很复杂!
我是否需要更改表格设计,以便用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 | 23:59:59 |
| 4 | 3 | 4 | 00:00:00 | 02:00:00 |
| 5 | 3 | 4 | 18:00:00 | 23:59:59 |
| 6 | 3 | 5 | 00:00:00 | 02:00:00 |
| 7 | 3 | 5 | 18:00:00 | 23:59:59 |
| 8 | 3 | 6 | 00:00:00 | 03:00:00 |
+----+---------+----------+-----------+------------+
然后使用以下类型(此查询是您提到的周二晚上10:00):
SELECT count(*) FROM `shop`
WHERE week_day=3
and open_hour<='22:00:00'
and close_hour>='22:00:00'
标签:php,mysql,database 来源: https://codeday.me/bug/20190521/1147135.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。