Mysql разделить время на временные интервалы в запросе
У меня есть таблица MySQL с доступным временем:
ID from till day
1 540 720 1
2 780 960 1
...
Время от и до - это просто минуты с полуночи, например, 9 утра = 9*60 = 540 и так далее.
from
а также till
Время может отличаться для разных поставщиков, и временные интервалы также могут быть разными.
Что мне нужно сделать, это сделать запрос, который выбирает результаты из этой таблицы, разбить на временные интервалы.
Например, один временной интервал составляет 60 минут, и результаты должны выглядеть следующим образом:
from till day
540 600 1
600 660 1
660 720 1
780 840 1
...
У вас есть идея, как я могу сделать это в MySQL?
Заранее спасибо.
2 ответа
Я бы создал таблицу со всеми временными интервалами за день. Это будет выглядеть примерно так:
CREATE TABLE time_slots (
time_slot_id INT(11) AUTO_INCREMENT,
start_time INT(11),
end_time INT(11)
);
Ваш запрос будет выглядеть примерно так:
SELECT ts.start_time, ts.end_time, avt.day
FROM available_times AS avt
JOIN time_slots ts
ON avt.from <= ts.end_time AND avt.till >= ts.start_time
ORDER BY ts.start_time;
Я не уверен, какими будут все ваши JOINS, так как я не знаю вашу схему, но, основываясь на ограниченной информации, я считаю, что это было бы полезно.
Если бы существовала таблица временных интервалов, как показано ниже, с внешним ключом PROVIDER_ID, она могла бы выглядеть следующим образом. Я включил поля DATETIME, потому что эти поля могут помочь вам при попытке запроса в точное время, если интервал был, скажем, 35 минут или что-то в этом роде. MySQL поставляется с некоторыми функциями DATE, которые могут помочь вам вместо того, чтобы пытаться использовать FROM и TILL в считанные минуты. (Я оставил ОТ и ДО в этом примере, но они, вероятно, не понадобятся)
Учитывая следующую таблицу:
ТАБЛИЦА: временные интервалы
ID FROM TILL DAY FROM_TIME TO_TIME PROVIDER_ID
1 540 630 1 2015-01-03 09:00:00 2015-01-03 10:30:00 4
2 780 960 1 2015-01-03 13:00:00 2015-01-03 16:00:00 16
3 600 660 2 2015-01-03 10:00:00 2015-01-03 11:00:00 7
4 660 720 1 2015-01-03 11:00:00 2015-01-03 12:00:00 9
5 780 840 2 2015-01-03 13:00:00 2015-01-03 14:00:00 12
6 600 630 3 2015-01-03 10:00:00 2015-01-03 10:30:00 14
ТАБЛИЦА: провайдеры
ID NAME
4 Provider 4
7 Provider 7
9 Provider 9
12 Provider 12
14 Provider 14
16 Provider 16
Вы можете использовать следующие возможные запросы, чтобы получить информацию о временном интервале и показать информацию о поставщике. Перед выполнением запроса вы можете передать тип INTERVAL и его значение в запрос на основе некоторой логики в вашем коде. Зацикливая свой код, вы можете собрать все временные интервалы, которые вам интересны в данный момент.
SELECT '60 Minute Slot', p.name, t.from_time, t.to_time, t.day
FROM time_slots t
JOIN providers p ON p.id = t.provider_id
WHERE DATE_ADD(from_time, INTERVAL 1 HOUR) = to_time
РЕЗУЛЬТАТ:
60 Minute Slot Provider 7 2015-01-03 10:00:00 2015-01-03 11:00:00 2
60 Minute Slot Provider 9 2015-01-03 11:00:00 2015-01-03 12:00:00 1
60 Minute Slot Provider 12 2015-01-03 13:00:00 2015-01-03 14:00:00 2
SELECT '30 Minute Slot', p.name, t.from_time, t.to_time, t.day
FROM time_slots t
JOIN providers p ON p.id = t.provider_id
WHERE DATE_ADD(from_time, INTERVAL 30 MINUTE) = to_time
РЕЗУЛЬТАТ:
30 Minute Slot Provider 14 2015-01-03 10:00:00 2015-01-03 10:30:00 3
Вы можете проверить функции MySQL DATE здесь: