Mysql select 两列之间的当前时间

Mysql select current time between two columns

我有一个时间表 table,其中有两列 time_fromtime_to,其值采用 24 小时格式,例如从和到是晚上 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'); 

please check sql fiddle

此查询有效

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。

如何使用当前时间并使用它在两列之间进行查询?

您可以使用:

SELECT *
FROM `ace_rp_inventory_locations_night`
WHERE (time_from_1 <= time_to_1 AND 23 between time_from_1 and time_to_1) OR
      (time_to_1 > time_to_1 AND 23 NOT BETWEEN time_from_1 and time_to_1);

注意:这使用 BETWEEN 影响范围终点的处理方式。您的问题没有具体说明要做什么。您可能应该明确说明不等式。