Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 03.08.2012, 16:06
sandroha sandroha вне форума
Прохожий
 
Регистрация: 27.05.2012
Сообщения: 2
Репутация: 10
По умолчанию Создать SQL запрос для суммирования столбца в последней строке

Подскажите кто нибудь. база Paradox. Необходимо составить SQL запрос так, чтобы Данные столбца 'col1' суммировались (1+2+3) и заносились в ячейки последней строки -- "ИТОГО" = 6

name....|col1|col2|
----------------------
aa........|..1..|..1..|
bb........|..2..|..1..|
cc........|...3..|..1..|
ИТОГО |...6..|..3..|

Такое можно сделать? Спасибо.
Ответить с цитированием
  #2  
Старый 03.08.2012, 16:40
MiraLaklamon MiraLaklamon вне форума
Новичок
 
Регистрация: 07.06.2012
Сообщения: 59
Версия Delphi: 6, 7
Репутация: 10
По умолчанию

Цитата:
Сообщение от sandroha
Подскажите кто нибудь. база Paradox. Необходимо составить SQL запрос так, чтобы Данные столбца 'col1' суммировались (1+2+3) и заносились в ячейки последней строки -- "ИТОГО" = 6

name....|col1|col2|
----------------------
aa........|..1..|..1..|
bb........|..2..|..1..|
cc........|...3..|..1..|
ИТОГО |...6..|..3..|

Такое можно сделать? Спасибо.
Насколько я знаю так не делают. Для этого обычно делают 2 запроса: один выбирает все записи, а второй получает суммы. Но если хочешь - можешь поизвращаться с оператором UNION:
Код:
SELECT name, col1, col2
FROM table
UNION
SELECT 'ИТОГО', SUM(col1), SUM(col2)
FROM table
И не забудь про сортировку (ORDER BY), чтобы слово 'ИТОГО' оказалось в последней записи.
Незнаю, правда, будет ли такое работать в BDE, но в MSSQL работает...
PS И повторю ещё раз - так делать очень нежелательно.
Ответить с цитированием
  #3  
Старый 05.08.2012, 19:31
Аватар Аватар вне форума
Прохожий
 
Регистрация: 16.11.2010
Сообщения: 8
Репутация: 10
По умолчанию

Если использовать какой-нибудь продвинутый Grid, то можно и без второго запроса. DBGridEh точно это умеет
Ответить с цитированием
  #4  
Старый 08.08.2012, 16:47
sandroha sandroha вне форума
Прохожий
 
Регистрация: 27.05.2012
Сообщения: 2
Репутация: 10
По умолчанию

С UNION в Delphi так и не попробовал, но потом попробую обязательно. В Database Desktop-е попробовал сработало, спасибо. А, почему нежелательно? Из-за возможных неправильных перестроений строк при сортировке? Или другое?

Поступил следующим образом. Создал временную базу (выборку из основной):
Код:
INSERT INTO  temp1.DB                                     
SELECT  name, col1, col2
FROM Base.DB
WHERE Data=01.01.1012
GROUP BY name, col1, col2
и в ней посчитал:

Код:
UPDATE temp1.DB
SET  col1 = (SELECT   sum(col1) as col1  FROM temp1.DB  WHERE not NAME = 'ИТОГО')
WHERE  NAME = 'ИТОГО'
почему во временной? потому что, в ней надо было сделать еще расчёты.
Всем спасибо за содействие

Последний раз редактировалось sandroha, 17.08.2012 в 13:15.
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 09:23.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter