@vincent_gun

Как правильно сформулировать поисковый вопрос к БД MySQL?

Доброго времени, уважаемые.

Заблудился на запросах к таблицам. Есть таблица сводных маршрутов поездов:

route_points
id route_id station_id date_arrival date_departure

route_id соответствует ссылается на другую таблицу, которая содержит названия маршрутов, station_id ссылается на станции (id, name), date_arrival/departure - дата прибытия и отправления соответственно.

Пример заполнения таблицы:

5bdb3da668438361372416.png

Мне необходимо реализовать поиск маршрута. Например, мне нужен рейс из станции [1] в станцию [3] на определённую дату, например, 9 сентября 2018 года. О номерах рейсов мне ничего не известно.

Подозреваю, что данную таблицу надо переделать, иначе каждый маршрут придётся ежедневно перебивать.

Вопросы:
1. Как реализовать график движения поездов по одному маршруту. Например, чтобы поезда по маршруту ходили ежедневно.
2. Как выполнить поиск по таблице определённого маршрута. Например, поезд едет по маршруту 1-2-3-4, мне необходимо проехать 1-2-3.

Благодарю за внимание.
  • Вопрос задан
  • 55 просмотров
Пригласить эксперта
Ответы на вопрос 2
Rsa97
@Rsa97
Для правильного вопроса надо знать половину ответа
Я бы сделал примерно так:
routes (route_id, station_id, arrival_timeshift, departure_timeshift)
routes_regular (route_id, weekday, deparure_time)
routes_irregular (route_id, deparure_date, departure_time)

В первой таблице сами маршруты и время прибытия/отправления от выхода на маршрут, в минутах.
Во второй таблице дни недели и время выходов на маршрут для регулярных маршрутов.
В третьей - дата и время выходов на маршрут для нерегулярных маршрутов.

Рейс ищем примерно так:
SELECT `s`.`route_id`, 
       ADDTIME(:date, TIME(ADDDATE(IFNULL(`rr`.`departure_time`, `ri`.`departure_time`), INTERVAL `s`.`departire_timeshift` MINUTE)) AS `departure_datetime`
  FROM `routes` AS `s`
  JOIN `routes` AS `e`
    ON `s`.`station_id` = :startStation
      AND `e`.`station_id` = :endStation
      AND `e`.`route_id` = `s`.`route_id`
      AND `e`.`arrival_time` > `s`.`departure_time`
  LEFT JOIN `routes_regular` AS `rr`
    ON `rr`.`route_id` = `s`.`route_id`
  LEFT JOIN `routes_irregular` AS `ri`
    ON `ri`.`route_id` = `s`.`route_id` 
      AND `ri`.`departure_date` <= :date
      AND `ri`.`departure_date` > SUBDATE(:date, INTERVAL 1 MONTH)
  WHERE DATE(ADDDATE(ADDTIME(`ri`.`departure_date`, `ri`.`departure_time`), 
                INTERVAL `s`.`departure_timeshift` MINUTE)) = :date
    OR (`rr`.`weekday` + FLOOR(HOUR(ADDDATE(`rr`.`departure_time`, 
            INTERVAL `s`.`departure_timeshift` MINUTE))/24)) % 7 = WEEKDAY(:date)
Ответ написан
dimonchik2013
@dimonchik2013
non progredi est regredi
1. Как реализовать график движения поездов по одному маршруту. Например, чтобы поезда по маршруту ходили ежедневно.

это делается не в базе, или процедурами, что не принято

2. Как выполнить поиск по таблице определённого маршрута. Например, поезд едет по маршруту 1-2-3-4, мне необходимо проехать 1-2-3.


select * from * where station_id in (1, 2, 3)
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
22 нояб. 2024, в 22:26
3500 руб./за проект
22 нояб. 2024, в 21:47
3000 руб./за проект
22 нояб. 2024, в 21:44
50000 руб./за проект