Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/3: Рейтинг темы: голосов - 3, средняя оценка - 5.00
 Аватар для drvolodko
224 / 68 / 33
Регистрация: 23.05.2014
Сообщений: 752
RAD XE3+

Доработка SQL-запроса

25.06.2018, 15:19. Показов 678. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Доброго дня, господа форумчане. Получилась у меня такая вот задачка - выбрать одно поле из двух таблиц по условию.
Есть два справочника Staff и GUsers. Содержат одинаковые значения полей TNUM (Staff таблица, которая загружается извне, поэтому связать их по ID очень проблематично и долго объяснять, почему так и только так). Второй это список ВИП из сотрудников. DateIn и DateOut в нем это даты начала и окончания периода действия привилегий. Надо чтобы выбирались нужные записи из них - если есть привилегии в данном диапазоне дат, то берем поле Tarif из таблицы GUSERS, если нет - то Prn из таблицы Staff. Пока что сделал так и это сработало, но пятая точка зудит, предчувствуя, что данное решение не совсем верное.
Delphi
1
2
3
4
5
sql.text:='Select Staff.FIO, Staff.TNUM, COALESCE(GUsers.Tarif, Staff.Prn) as Prn '+
            'From Staff Left join GUsers on Staff.TNUM=GUsers.TNUM '+
            'where Staff.PN='+QuotedStr(PN)+
            ' and Not Staff.Tnum in (Select TNUM From gusers where (DateIn>=:din '+
            'and DateOut<=:dot )) order by fio';
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
25.06.2018, 15:19
Ответы с готовыми решениями:

Доработка запроса SQL
Есть запрос: SELECT Gorod.Nazvanie_Goroda, Organization.Nazvanie_Organization, Abonent.Phone_Abonenta FROM и так далее... Как...

Доработка SQL-запроса
Добрый день, господа. Прошу Вашей помощи в доработке запросов. Дело в том, что когда писались (и благодаря Вашей помощи тоже) эти запросы...

Доработка SQL-запроса вновь
Добрый день, господа. Подобная тема поднималась на форуме, но там не совсем то, что мне нужно. Необходимо выполнить update таблицы выборкой...

4
 Аватар для krapotkin
6849 / 4676 / 1464
Регистрация: 14.04.2014
Сообщений: 20,671
Записей в блоге: 21
25.06.2018, 18:10
а почему бы просто в условие джойна не внести ваши даты?
0
 Аватар для drvolodko
224 / 68 / 33
Регистрация: 23.05.2014
Сообщений: 752
26.06.2018, 13:02  [ТС]
Delphi
1
2
3
sql.text:='Select Staff.FIO, Staff.TNUM, COALESCE(GUsers.Tarif, Staff.Prn) as Prn '+
'From Staff Left join GUsers on Staff.TNUM=GUsers.TNUM where GUsers.DateIn>=:din and GUsers.DateOut<=:dot '+
 'where Staff.PN='+QuotedStr(PN)+ ' order by fio';
krapotkin, так?
0
 Аватар для krapotkin
6849 / 4676 / 1464
Регистрация: 14.04.2014
Сообщений: 20,671
Записей в блоге: 21
26.06.2018, 13:15
нет.
условие в join это обычное условие и может содержать AND и OR но не может содержать WHERE
замените его на AND
ну и ессно лучше если вы воспользуетесь параметрами а не будете конструировать строку запроса каждый раз.
1
 Аватар для drvolodko
224 / 68 / 33
Регистрация: 23.05.2014
Сообщений: 752
26.06.2018, 16:21  [ТС]
krapotkin, понял. Попробую.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.06.2018, 16:21
Помогаю со студенческими работами здесь

доработка запроса в БД
Здравствуйте! Вот такая проблемка:как сделать так чтобы в ряду было по 4 картинки, а остальные 4 картинки переносились на следующий ряд и...

доработка запроса на выборку!!!
Есть следующий запрос, на выборку данных по типам сделок. В запросе данные берутся из разных таблиц, в том числе и таблицы &quot;Жилищный...

Доработка запроса, просьба подсказать
Здравствуйте уважаемые, имеется запрос выборки из 4х таблиц SELECT trm_out_shift_open.date AS `Дата`, trm_in_store.`name` AS...

Доработка БД MS SQL
Добрый день, господа. Так как мой уровень, как проектировщика, в данный момент истории равен уровню &quot;днище&quot; с ареалом обитания...

Доработка кода SQL
Друзья, дико нужна помощь. Есть обработка которая вносит данные из excel в программу стек )расчет жкх) на базе sql Необходимо ее чутка...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru