【发布时间】:2021-03-22 17:03:16
【问题描述】:
我有一个日程表,其中有两列 time_from 和 time_to,其值采用 24 小时格式,例如 from 和 to 是晚上 9 点到凌晨 1 点,而不是 time_from 和 time_to 分别为 21 和 1 .
现在我需要检查当前时间是否在这两列之间
如果现在时间是晚上 11 点,我应该得到在晚上 11 点之间的列值是 23 和 1 的列
CREATE TABLE `ace_rp_inventory_locations_night` (
`id` int(11) NOT NULL,
`name` varchar(255) DEFAULT NULL,
`time_from` varchar(255) DEFAULT NULL,
`time_to` varchar(255) DEFAULT NULL
);
INSERT INTO ace_rp_inventory_locations_night (id, name, time_from, time_to)
VALUES (1, 'test', '23','1');
这个查询有效
SELECT *
FROM `ace_rp_inventory_locations_night`
WHERE time_from_1 <= '23'
AND time_to_1 >= '23'
如果时间在 24 小时范围内,即 20 和 24,但凌晨 1 点的值是 1,并且上面的查询不起作用,因为 23 和 1 没有完全满足条件,我正在用当前时间检查它,所以如果时间是凌晨 2 点,我必须在查询中传递 2。
如何使用当前时间在两列之间进行查询?
【问题讨论】:
-
这里没有 time_from_1 或 time_to_1