|
2 / 2 / 1
Регистрация: 15.08.2014
Сообщений: 30
|
||||||
Объединение двух связанных запросов26.11.2016, 23:18. Показов 2147. Ответов 7
Метки нет (Все метки)
Доброго времени суток.
Помогите пожалуйста с SQL запросом для выборки двух взаимосвязанных запросов. То есть в БД существуют 3 взаимосвязанных таблиц: Таблица "Заказ" - хранятся заказы с датами предполагаемых заказов и номера на которые поступили заказы Таблица "Номер" - список номеров гостиницы Таблица "Класс обслуживания" - дополнительный описательный список класса номера (стоимость и т.д. и т.п.) Так вот, мне нужно получить список номеров, которые свободны на заданный промежуток времени, в список должны включаться:
На данный момент я сделал получение списка свободных номеров без описания (просто номера):
Подскажите пожалуйста как вывести данные описания.
0
|
||||||
| 26.11.2016, 23:18 | |
|
Ответы с готовыми решениями:
7
Программное создание связанных таблиц и экспорт запросов и форм |
|
2 / 2 / 1
Регистрация: 15.08.2014
Сообщений: 30
|
|
| 26.11.2016, 23:37 [ТС] | |
|
Ох как я заработался уже...
Извините за странную тему само решённую. Решил как и обычно через INNER JOIN (А заработавшись пытался достать тоже через вложенный запрос). Не по теме: Бывает такое, строчишь вопрос в тему, уже на грани нажатия кнопки Создать, но потом погуляешь по комнате и решение само вспоминается.
0
|
|
|
26826 / 14506 / 3192
Регистрация: 28.04.2012
Сообщений: 15,782
|
|||||||||||
| 26.11.2016, 23:40 | |||||||||||
Сообщение было отмечено PandoraBox как решение
Решение
Надо связать таблицы Номер и [Класс обслуживания]. В SQL-виде во From
И кстати, временной период описан неверно. Номер может быть занят раньше даты в условии или освобожден после нее. Условие занятого в период номера подразумевает, что дата въезда меньше или равна наибольшей дате периода, а дата выезда больше или равна наименьшей дате периода
0
|
|||||||||||
|
2 / 2 / 1
Регистрация: 15.08.2014
Сообщений: 30
|
|||||||
| 27.11.2016, 13:10 [ТС] | |||||||
0
|
|||||||
|
26826 / 14506 / 3192
Регистрация: 28.04.2012
Сообщений: 15,782
|
|
| 27.11.2016, 13:51 | |
|
Нет, ошибаетесь. Пример: дата въезда - #10/31/2016#, выезда - #11/4/2016#. По Вашей формуле не попадает, а номер занят.
0
|
|
|
2 / 2 / 1
Регистрация: 15.08.2014
Сообщений: 30
|
|||||||||||||||||||||
| 28.11.2016, 21:10 [ТС] | |||||||||||||||||||||
На деле, c датой: Желаемое прибытие - 02.11.2016 Желаемый съезд - 28.11.2016 Получилось так, что ваш код:
Но зато он учитывает ситуацию, когда желаемые дата и съезд - 11.1.2016 и 11.3.2016 соответственно. Возможно я обошёлся очередным топором, но я объединил наши условия, и они с изначальными проверками вроде как проходят:
0
|
|||||||||||||||||||||
|
26826 / 14506 / 3192
Регистрация: 28.04.2012
Сообщений: 15,782
|
|
| 28.11.2016, 21:50 | |
|
Вы не дали свою базу. К сожалению. Поэтому привожу самодельную. 2 таблицы - Заказы, Номер с минимальным количеством полей. Только нужные для решения. Смотрим данные из т.Заказ. Там воспроизведены Ваши даты. Выполняем ЗапросДаты и видим, что Ваши возражения неверны. Запрос только с моим условием отсеивает занятые номера
1
|
|
|
2 / 2 / 1
Регистрация: 15.08.2014
Сообщений: 30
|
|
| 29.11.2016, 09:19 [ТС] | |
|
Ахахах.
Да, вы были правы! Моя грубейшая ошибка - невнимательность. При тестировании вашего запроса я попросту вводил с клавиатуры его, в следствии чего мною была допущена ошибка - изменил местами даты которые вы приводите в своём запросе. Из-за невнимательности пришлось делать костыли. Спасибо большое!
0
|
|
| 29.11.2016, 09:19 | |
|
Помогаю со студенческими работами здесь
8
Объединение запросов
Объединение запросов в один, использование условия Объединение запросов или создание таблицы Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Символьное дифференцирование
igorrr37 13.02.2026
/ *
Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2).
Унарный минус обозначается как !
*/
#include <iostream>
#include <stack>
#include <cctype>. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога
Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
|
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
|