3 / 3 / 0
Регистрация: 19.02.2015
Сообщений: 33

Delphi DB. Снова о вложенных запросах

16.11.2015, 14:06. Показов 1166. Ответов 29
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Пересмотрел все темы по данному вопросу, ответа не нашел, поэтому попрошу помощи.
Суть вопроса:
Из MS SQL делается выборка путем сложного динамического запроса ADOQUERY1. Т.е. резултатом выборки каждый раз являются разные значения, в зависимости от условий.(Дата от и до, номер, состояние и т.д.) Текст запроса каждый раз разный. Результат отправляется в DBGrid.
Так же создал другой статический запрос ADOQUERY2 такого плана:
SQL
1
2
3
4
5
6
7
8
SELECT     h5, 
COUNT(h6) AS Всего, 
SUM(CASE h14 WHEN 'OK' THEN 1 ELSE 0 END) AS OK,
SUM(CASE h14 WHEN 'Брак' THEN 1 ELSE 0 END) AS Брак, 
SUM(CASE h14 WHEN 'Не изм.' THEN 1 ELSE 0 END) AS Не_измерено
FROM         simatic
GROUP BY h5
ORDER BY h5
который делает сводную таблицу. И результаты отправляет в другой грид, вопрос в том, что нужно во второй запрос вставить первый, чтобы сводная таблица выдавала результаты только из ранее отобраных значений. Т.е. между FROM и GROUP нужно вставить WHERE (ADOQUERY1.SQL) Что-то типа такого, но как это сделать, хоть убей не пойму.
Буду признателен за совет.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.11.2015, 14:06
Ответы с готовыми решениями:

Именование столбцов во вложенных запросах
Здравствуйте, у меня есть такой запрос: SELECT top(50) g.inc_id, g.name, g.?? ...

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

Graphql n+1 во вложенных запросах, даже с prefetch_related
Всем привет, на проекте использую graphql из библиотеки graphene-django для django. И заметил такую не приятную проблему, если пытаться...

29
5647 / 4489 / 1089
Регистрация: 29.08.2013
Сообщений: 27,977
Записей в блоге: 3
16.11.2015, 16:17
пишите результат первого запроса во временную таблицу
а во второй запрос ее подставляйте
0
3 / 3 / 0
Регистрация: 19.02.2015
Сообщений: 33
16.11.2015, 16:46  [ТС]
Т.е. второй запрос делать уже не из БД, а из временной таблицы?
0
5647 / 4489 / 1089
Регистрация: 29.08.2013
Сообщений: 27,977
Записей в блоге: 3
16.11.2015, 17:02
philosoffer, временная таблица то хранится в БД
просто второй запрос делаете к БД, но, используя join, подключаете времянку
0
3 / 3 / 0
Регистрация: 19.02.2015
Сообщений: 33
16.11.2015, 17:18  [ТС]
А. Кажется понял. Попробую. Спасибо.
0
 Аватар для krapotkin
6828 / 4657 / 1461
Регистрация: 14.04.2014
Сообщений: 20,599
Записей в блоге: 20
17.11.2015, 10:28
ну вообще-то должна работать конструкция

SQL
1
SELECT t1.f1,t1.f2,t1.f3 FROM table1 t1 WHERE t1.id IN (SELECT t2.id FROM fable2 t2 WHERE ...)
0
5647 / 4489 / 1089
Регистрация: 29.08.2013
Сообщений: 27,977
Записей в блоге: 3
17.11.2015, 15:23
krapotkin,
конструкция может работать и такая

SQL
1
2
SELECT * FROM a
JOIN (SELECT * FROM b) b ON a.1=b.1
но зачем начинать сразу со сложного?
0
 Аватар для krapotkin
6828 / 4657 / 1461
Регистрация: 14.04.2014
Сообщений: 20,599
Записей в блоге: 20
17.11.2015, 15:57
ну, временные таблицы тоже так себе вариант
надо же иметь в виду, что они должны быть уникальными для каждой транзакции, да?
0
5647 / 4489 / 1089
Регистрация: 29.08.2013
Сообщений: 27,977
Записей в блоге: 3
17.11.2015, 19:17
krapotkin, я вполне себе использую #t и все работает
0
3 / 3 / 0
Регистрация: 19.02.2015
Сообщений: 33
17.11.2015, 19:40  [ТС]
В том то и дело, что не очень хочется использовать временные таблицы. Говорят по возможности этого нужно избегать.
SQL
1
SELECT t1.f1,t1.f2,t1.f3 FROM table1 t1 WHERE t1.id IN (SELECT t2.id FROM fable2 t2 WHERE ...)
Такой вариант не подходит, ибо вложенный запрос каждый раз разный.

Пробовал присваивать переменной значение
Delphi
1
a:='('+ADOQuery1.SQL.text+')';
Потом вставлять в запрос
Delphi
1
SQL.Add(quotedstr (a));
Но не получается. Появляются "левые" одиночные кавычки по краям вложенного запроса и возле условия h5.
SQL
1
2
3
4
5
6
7
8
9
10
11
SELECT     h5 AS h5, 
COUNT(h6) AS Всего, 
SUM(CASE h14 WHEN 'OK' THEN 1 ELSE 0 END) AS OK, 
SUM(CASE h14 WHEN 'Брак' THEN 1 ELSE 0 END) AS Брак, 
FROM    
'(SELECT * FROM simatic
where id_zaznamu >0
and h5 Like''10101''
Order by h6+0
)'
GROUP BY h5
И не работает.
0
5647 / 4489 / 1089
Регистрация: 29.08.2013
Сообщений: 27,977
Записей в блоге: 3
17.11.2015, 19:56
Цитата Сообщение от philosoffer Посмотреть сообщение
Говорят по возможности этого нужно избегать.
кто говорит?
временные таблицы это такой же объект БД как и остальные. вам там не говорят что хранимки нельзя использовать?

Цитата Сообщение от philosoffer Посмотреть сообщение
Появляются "левые" одиночные кавычки по краям вложенного запроса
Описание quotedstr(S : string)
Функция приводит строку S в форму цитаты.
Функция добавляет символ одиночной кавычки ( ' ) в начало и конец строки, а так же дублирует каждый одиночный символ кавычки внутри строки.
а просто добавить SQL.Add(a);?
0
3 / 3 / 0
Регистрация: 19.02.2015
Сообщений: 33
17.11.2015, 19:56  [ТС]
Так, с кавычками разобрался. Убрал quotedstr стало нормально, но все равно не работает. Выдает ошибку, что GROUP не работает во вложенных запросах без оператора ТОР, а его нужно вставить в тело переменной. Блин, буду бороться.
0
5647 / 4489 / 1089
Регистрация: 29.08.2013
Сообщений: 27,977
Записей в блоге: 3
17.11.2015, 20:04
philosoffer,
покажите тот запрос с ошибкой
0
3 / 3 / 0
Регистрация: 19.02.2015
Сообщений: 33
17.11.2015, 20:06  [ТС]
Сори, не GROUP а ORDER BY Думал об одном, писал другое.
0
5647 / 4489 / 1089
Регистрация: 29.08.2013
Сообщений: 27,977
Записей в блоге: 3
17.11.2015, 20:09
philosoffer,
уберите Order by, он не нужен во вложенном запросе

Не по теме:

то то я смотрю - нет нигде Group by

0
3 / 3 / 0
Регистрация: 19.02.2015
Сообщений: 33
17.11.2015, 20:12  [ТС]
SQL
1
2
3
4
5
6
7
8
9
10
11
SELECT     h5 AS номер, 
COUNT(h6) AS Всего, 
SUM(CASE h14 WHEN 'OK' THEN 1 ELSE 0 END) AS OK, 
SUM(CASE h14 WHEN 'Брак' THEN 1 ELSE 0 END) AS Брак
FROM         
(SELECT * FROM simatic
WHERE h5<>'XXXXX          '
AND h5 LIKE'10101'
ORDER BY h6+0
)
GROUP BY h5
Цитирую сообщение об ошибке
Предложение ORDER BY не допускается в ..., вложенных запросах,... если не указано ТОР или FOR XML
0
5647 / 4489 / 1089
Регистрация: 29.08.2013
Сообщений: 27,977
Записей в блоге: 3
17.11.2015, 20:14
уберите строку 9 в вашем вложении
0
3 / 3 / 0
Регистрация: 19.02.2015
Сообщений: 33
17.11.2015, 20:19  [ТС]
Не могу, вернее это не удобно. Вложенный запрос изначально производит выборку и сортирует для удобства пользователя. Потом на основе этой выборки я делаю сводный отчет и ORDER BY добавляется автоматически в переменной "а" из текста запроса.

Добавлено через 1 минуту
Для этого мне нужно изменить первый запрос. Но пользователь, он ведь тупой бывает, и отсортировать вручную забудет. Потом проблемы.

Добавлено через 1 минуту
Попробую запихнуть запрос в МЕМО, убрать лишнее, потом использовать.
0
5647 / 4489 / 1089
Регистрация: 29.08.2013
Сообщений: 27,977
Записей в блоге: 3
17.11.2015, 20:20
philosoffer, да зачем вам сам запрос менять?
вы когда делаете
Delphi
1
SQL.Add(a);
в переменной "а" уберите последнюю строку
0
3 / 3 / 0
Регистрация: 19.02.2015
Сообщений: 33
17.11.2015, 20:21  [ТС]
Подскажите как?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
17.11.2015, 20:21
Помогаю со студенческими работами здесь

Снова хром, снова сапопроизвольно открывается, снова bkrfdf.xyz и казино
Здравствуйте! Собственно, проблема уже не новая, хотя, как показывают сообщения форума, за последние дни выскочившая у многих. Через...

Отображение вложенных директорий без вложенных файлов (shlwapi.dll)
Здравствуйте. Вопрос: существует ли функция в shlwapi (или других библиотеках), позволяющая по имени (или идентификатору) какой-либо...

Снова про OpenCL в Delphi + программное измерение загрузки CPU & GPU (работающий пример)
Уже более года назад приводил здесь на форуме пример работы с OpenCL в связке с Delphi - ...

Как сделать чтобы таймер дойдя до 0 стартовал снова и снова?
Здравствуйте :) Как сделать чтобы таймер дойдя до 0 стартовал снова и снова? TimerSec = 59; TimerMin = 6; for(int i = TimerSec;...

HP 625 снова и снова перезагружается в безопасный не заходит
Ребята помогите , проблема вот какая врубаю я ноут он доходит до заставки майкрософта и снова перезагружается в безопасный не заходит, ...


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

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Опции темы

Новые блоги и статьи
Unity 4D
GameUnited 13.06.2025
Четырехмерное пространство. . . Звучит как что-то из научной фантастики, правда? Однако для меня, как разработчика со стажем в игровой индустрии, четвертое измерение давно перестало быть абстракцией из. . .
SSE (Server-Sent Events) в ASP.NET Core и .NET 10
UnmanagedCoder 13.06.2025
Кажется, Microsoft снова подкинула нам интересную фичу в новой версии фреймворка. Работая с превью . NET 10, я наткнулся на нативную поддержку Server-Sent Events (SSE) в ASP. NET Core Minimal APIs. Эта. . .
С днём независимости России!
Hrethgir 13.06.2025
Решил побеседовать, с утра праздничного дня, с LM о завоеваниях. То что она написала о народе, представителем которого я являюсь сам сначала возмутило меня, но дальше только смешило. Это чисто. . .
Лето вокруг.
kumehtar 13.06.2025
Лето вокруг. Наполненное бурями и ураганами событий. На фоне магии Жизни, священной и вечной, неумелой рукой человека рисуется панорама душевного непокоя. Странные серые краски проникают и. . .
Популярные LM модели ориентированы на увеличение затрат ресурсов пользователями сгенерированного кода (грязь -заслуги чистоплюев).
Hrethgir 12.06.2025
Вообще обратил внимание, что они генерируют код (впрочем так-же ориентированы разработчики чипов даже), чтобы пользователь их использующий уходил в тот или иной убыток. Это достаточно опытные модели,. . .
Топ10 библиотек C для квантовых вычислений
bytestream 12.06.2025
Квантовые вычисления - это та область, где теория встречается с практикой на границе наших знаний о физике. Пока большая часть шума вокруг квантовых компьютеров крутится вокруг языков высокого уровня. . .
Dispose и Finalize в C#
stackOverflow 12.06.2025
Работая с C# больше десяти лет, я снова и снова наблюдаю одну и ту же историю: разработчики наивно полагаются на сборщик мусора, как на волшебную палочку, которая решит все проблемы с памятью. Да,. . .
Повышаем производительность игры на Unity 6 с GPU Resident Drawer
GameUnited 11.06.2025
Недавно копался в новых фичах Unity 6 и наткнулся на GPU Resident Drawer - штуку, которая заставила меня присвистнуть от удивления. По сути, это внутренний механизм рендеринга, который автоматически. . .
Множества в Python
py-thonny 11.06.2025
В Python существует множество структур данных, но иногда я сталкиваюсь с задачами, где ни списки, ни словари не дают оптимального решения. Часто это происходит, когда мне нужно быстро проверять. . .
Работа с ccache/sccache в рамках C++
Loafer 11.06.2025
Утилиты ccache и sccache занимаются тем, что кешируют промежуточные результаты компиляции, таким образом ускоряя последующие компиляции проекта. Это означает, что если проект будет компилироваться. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru