Форум программистов, компьютерный форум, киберфорум
Delphi: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.94/18: Рейтинг темы: голосов - 18, средняя оценка - 4.94
0 / 0 / 0
Регистрация: 06.02.2013
Сообщений: 6

Результат запроса SQL sum() вставить в вычисляемое поле CalcFields

06.02.2013, 17:04. Показов 3822. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Delphi, BDE, Paradox, DBGridEh

Подскажите кто-нибудь, возникла проблема вставки результата запроса в поле CalcFields.
допустим, есть база
Data, Name, Prihod_sut, Prihod_nm, Rashod --> необходимо рассчитать СУММУ например Prihod_sut с 1 числа по выбранный день (т.е. с начала месяца) и записать результат в Prihod_nm. Наименований может быть несколько.
Ставлю в CalcFields код:
SQL
1
2
3
4
5
6
7
8
9
10
  WITH DM.Query1 do
   BEGIN
    Close;       
    SQL.Clear;
    SQL.Add('SELECT   sum(PRIHOD_SUT) as PRIHOD_NM ');
    SQL.Add('FROM "Base.db"  ');
    SQL.Add('WHERE   (Data BETWEEN ''01.01.2013''  and ''25.01.2013'')  ');
    SQL.Add('GROUP BY  Name');
    OPEN;
   END;
Запрос суммирует диапазон с 1 янв. по 25 янв. по каждому наименованию. Затем, присваиваю результат переменной:
Delphi
1
2
   a := DM.Query1.FieldByName('PRIHOD_NM').AsInteger;
   DM.Query1.FieldByName('PRIHOD_NM_calc').AsInteger := a;
Однако результат записывается во все ячейки поля PRIHOD_NM_calc, а надо чтобы по каждому наименованию суммировалась своя СУММА с начала месяца.

Понимаю, что надо как-то привязать в Name, но как не пойму. Если в WHERE поставить (NAME = ''Кирпич'') and , тогда будет искать конкретно по этому наименованию, но ведь их может быть много, не писать же для каждого...
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
06.02.2013, 17:04
Ответы с готовыми решениями:

Вставить вычисляемое значение из запроса в форму
Имеется таблица с продукцией, на ее основе создана форма - т.е. у каждого продукта в форме стоит наименование, описание, картинка. ...

Вывод результата запроса в вычисляемое текстовое поле
Необходимо вывести один (и единственный) результат запроса в вычисляемое текстовое поле. ввел в текстовое поле следующие варианты...

Добавить вычисляемое поле, которое является результатом запроса
Всем привет. Я составил запрос, который вычисляет объем каждого потребителя за первый квартал. select s.k_potr as Код, s.name as Имя,...

2
 Аватар для rdama
569 / 292 / 12
Регистрация: 28.01.2011
Сообщений: 1,326
06.02.2013, 17:18
Добавь в выборку поле Name
0
0 / 0 / 0
Регистрация: 06.02.2013
Сообщений: 6
07.02.2013, 13:24  [ТС]
Цитата Сообщение от rdama Посмотреть сообщение
Добавь в выборку поле Name
Я уже так делал. Если пишешь в первой строке Prihod_sut, допустим 10 , тогда весь столбец Prihod_sut_calc заполняется цифрой 10.
А если в любой ниже, то вообще ничего не происходит.

Добавлено через 17 часов 27 минут
В итоге, решил следующим образом:
SQL
1
2
3
4
5
6
7
8
9
10
WITH DM.Query1 do
   BEGIN
    Close;       
    SQL.Clear;
    SQL.ADD('SELECT   [COLOR="Blue"]NAME[/COLOR], sum(PRIHOD_SUT) as PRIHOD_NM ');
    SQL.ADD('FROM "Base.db"  ');
    SQL.ADD('WHERE   (Data BETWEEN ''01.01.2013''  and ''25.01.2013'') [COLOR="Blue"] and (NAME = '''+DM.Query1.FieldByName('NAME').Value ')[/COLOR]');
    SQL.ADD('GROUP BY  Name');
    OPEN;
   END;
Добавлено через 41 минуту
Цитата Сообщение от rdama Посмотреть сообщение
Добавь в выборку поле Name
Я уже так делал. Если пишешь в первой строке Prihod_sut, допустим 10 , тогда весь столбец Prihod_sut_calc заполняется цифрой 10.
А если в любой ниже, то вообще ничего не происходит.

Добавлено через 17 часов 27 минут
В итоге, решил следующим образом:
SQL
1
2
3
4
5
6
7
8
9
10
WITH DM.Query1 do
   BEGIN
    Close;       
    SQL.Clear;
    SQL.ADD('SELECT   NAME, sum(PRIHOD_SUT) as PRIHOD_NM ');
    SQL.ADD('FROM "Base.db"  ');
    SQL.ADD('WHERE   (Data BETWEEN ''01.01.2013''  and ''25.01.2013'') and (NAME = '''+DM.Query1.FieldByName('NAME').Value +''')');
    SQL.ADD('GROUP BY  Name');
    OPEN;
   END;
>
Кроме NAME в SELECT, еще добавил в WHERE --> and (NAME = '''+DM.Query1.FieldByName('NAME').Value +''') И тогда всё заработало.

Только возникла ещё одна проблема -- в BeforePost пытаюсь сохранить то что получилось в PRIHOD_NM_calc в PRIHOD_NM
добавив DM.Query1.FieldByName('PRIHOD_NM').Value := DM.Query1.FieldByName('PRIHOD_NM_calc'). Value;

но результат не сохраняется в базе.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
07.02.2013, 13:24
Помогаю со студенческими работами здесь

Вычисляемое поле в запросе с использованием другого вычисляемого поля этого же запроса
Возможно вопрос глупый и решается достаточно просто, прошу отнеситесь с пониманием к самостоятельно плавающим в аксессе))) Ситуация...

Вывод SQL запроса разницы двух SUM в PHP
Добрый день. Пишу программу учета доходов и расходов. Остаток для каждой выводимой строки хочу вычислять как $t + SUM(`Prihod`) -...

результат запроса linq to sql содержит данные обеих таблиц, картографированных на классы. Я хочу результат присвоить в GridControl.DataSource
Здравствуйте! У меня есть две таблицы T1(id_t1(PK),name), T2(id_t2(PK), id_t1(FK), date) отображенных на классы при помощи linq to sql и...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если. . .
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
Уведомление о неверно выбранном значении справочника
Maks 06.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "НарядПутевка", разработанного в конфигурации КА2. Задача: уведомлять пользователя, если в документе выбран неверный склад. . .
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru