|
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
|
|
Interbase SQL запрос19.03.2020, 19:27. Показов 762. Ответов 10
Не получается сочинить селективный запрос. Суть.
В таблице БД значимые для запроса два поля: дата (DAT) и идентификатор (ID_G). Примерно так: 12.01.2019 10 16.01.2019 15 18.01.2019 16 20.01.2019 17 23.01.2019 20 25.01.2019 45 08.01.2020 11 09.01.2020 20 11.01.2020 22 20.01.2020 45 21.01.2020 55 22.01.2020 15 31.01.2020 98 Дата в возвращаемом результате не нужна, а используется для определения фильтра периодов в запросе. Запрос должен вернуть только те значения id_g, которые совпадают в указанных периодах. Периодов всегда только два. В примере выше периоды такие: 1. dat >= '01.01.2019' and dat < '01.02.2019' и 2. dat >= '01.01.2020' and dat < '01.02.2020' И запрос должен вернуть значения: 15 20 45 Именно эти значения есть в обоих периодах. Может ли кто сформировать болванку такого запроса?
0
|
|
| 19.03.2020, 19:27 | |
|
Ответы с готовыми решениями:
10
SQL запрос, работающий в MS SQL Menegment'e не работает в делфи SQL и ComboBox в Delphi. Нужно чтобы при выборе специальности в комбобоксе это значение вносилось в SQL запрос |
| 19.03.2020, 22:01 | ||||||
|
самый простой вариант
1
|
||||||
|
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
|
||
| 19.03.2020, 22:51 [ТС] | ||
|
qwertehok, спасибо. Запрос рабочий (я что-то похожее пытался сделать, но запутался в деталях).
Единственный недостаток - это неприемлемое время выполнение такого запроса.
Осторожно спрошу: может как-то можно оптимизировать... Добавлено через 16 минут qwertehok, ещё раз спасибо за подсказку (подсказки двигатель прогресса и неопытных разработчиков БД). Запрос оптимизировал так, что он выполняется меньше чем за секунду (использовано CTE).
0
|
||
|
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
|
|||||||
| 19.03.2020, 23:11 [ТС] | |||||||
|
Да, нет, дружище, индексы какие были, такие и остались.
А CTE в Firebird'е есть. Пользуюсь уже много лет. (префикс Interbase в теме лишь потому, что в списке префиксов нет FB) Если запрос перевести на похожие наименования, то выглядит он так:
0
|
|||||||
| 19.03.2020, 23:20 | ||||||
|
ааа, Firebird
а так проверь, CTE то нужно что бы сформировать подзапрос для нескольких использований, а у тебя смысла от него нет
0
|
||||||
|
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
|
|
| 19.03.2020, 23:46 [ТС] | |
|
Запрос шустрый, но результат возвращается с ошибками: может быть одно значение в обоих периодах, но его нет в выходном НД, или в одном периоде есть, в другом нет, а в НД возвращается. Не все, но примерно треть значений не те, какие нужны.
Наши первый и второй запросы возвращают из реальной таблицы одинаковое количество строк и одинаковый набор значений - правильный.
0
|
|
|
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
|
|
| 20.03.2020, 08:03 [ТС] | |
|
Да, их может быть много в периоде.
А в строке 7 твоего запроса это разве не группировка по id? Проба сделать группировку во вложенных запросах привела к нулевому результату. К сожалению, не совсем понимаю логику твоего запроса.
0
|
|
| 20.03.2020, 09:19 | ||||||
0
|
||||||
|
1076 / 989 / 340
Регистрация: 07.08.2012
Сообщений: 2,790
|
|
| 20.03.2020, 10:11 [ТС] | |
|
Именно так я и пробовал. Получается пустой НД.
В вопросе была только часть основного запроса. Весь запрос затолкал в ХП и он прекрасно работает. Спасибо за поддержку и внимание.
0
|
|
| 20.03.2020, 10:11 | |
|
Помогаю со студенческими работами здесь
11
Sql запрос sql запрос
sql запрос Запрос в SQL Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер
Написал заготовку:
dotnet new console --aot -o UrlHandler
var items = args. Split(":");
var tag = items;
var id = items;
var executable = args;. . .
|
Отправка уведомления на почту при изменении наименования справочника
Maks 24.03.2026
Программная отправка письма электронной почты на примере изменения наименования типового справочника "Склады" в конфигурации БП3. Перед реализацией необходимо выполнить настройку системной учетной. . .
|
модель ЗдравоСохранения 5. Меньше увольнений- больше дохода!
anaschu 24.03.2026
Теперь система здравосохранения уменьшает количество увольнений.
9TO2GP2bpX4
a42b81fb172ffc12ca589c7898261ccb/
https:/ / rutube. ru/ video/ a42b81fb172ffc12ca589c7898261ccb/
Слева синяя линия -. . .
|
Midnight Chicago Blues
kumehtar 24.03.2026
Такой Midnight Chicago Blues, знаешь?. .
Когда вечерние улицы становятся ночными, а ты не можешь уснуть. Ты идёшь в любимый старый бар, и бармен наливает тебе виски. Ты смотришь на пролетающие. . .
|
|
SDL3 для Desktop (MinGW): Вывод текста со шрифтом TTF с помощью библиотеки SDL3_ttf на Си и C++
8Observer8 24.03.2026
Содержание блога
Финальные проекты на Си и на C++:
finish-text-sdl3-c. zip
finish-text-sdl3-cpp. zip
|
Жизнь в неопределённости
kumehtar 23.03.2026
Жизнь — это постоянное существование в неопределённости. Например, даже если у тебя есть список дел, невозможно дойти до точки, где всё окончательно завершено и больше ничего не осталось. В принципе,. . .
|
Модель здравоСохранения: работники работают быстрее после её введения.
anaschu 23.03.2026
geJalZw1fLo
Корпорация до введения программа здравоохранения имела много невыполненных работниками заданий, после введения программы количество заданий выросло.
Но на выплатах по больничным это. . .
|
Контроль уникальности заводского номера
Maks 23.03.2026
Алгоритм контроля уникальности заводского (или серийного) номера на примере нетипового документа выдачи шин для спецтехники с табличной частью, разработанного в конфигурации КА2.
Номеклатура. . .
|