Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2007.04.08;
Скачать: CL | DM;

Вниз

Сумма   Найти похожие ветки 

 
Cara ©   (2007-03-14 11:29) [0]

Добрый день!
Как посчитать сумму по столбцу в DBGrid.


 
Плохиш ©   (2007-03-14 11:33) [1]

with DBGrid.DataSource.DataSet do
begin
 First;
 Summa := 0;
 while not eof do
 begin
   Summa := Summa + FieldByName("pole").AsFloat;
   Next;
 end;
end;

Но настоятельно советую начать в конце концов изучение теории.


 
Cara ©   (2007-03-14 11:40) [2]

А не переходя по полям по очереди. Ну в случае большой таблицы это не есть хорошо. В Acess есть функция Sum(), а как это в Delphi?


 
Плохиш ©   (2007-03-14 11:44) [3]


> Cara ©   (14.03.07 11:40) [2]

Вы разберитесь сначала, Вам "посчитать сумму по столбцу в DBGrid" или с помощью SQL-запроса?


 
Ega23 ©   (2007-03-14 11:46) [4]


> А не переходя по полям по очереди.


А никак.


> В Acess есть функция Sum(), а как это в Delphi?


функция Sum() есть в любой СУБД, поддерживающей ANSI SQL.


 
Reindeer Moss Eater ©   (2007-03-14 11:48) [5]

А не переходя по полям по очереди.
Если "не проходя", то можно просто угадать правильную сумму.
Random тебе поможет.


 
DimonS ©   (2007-03-14 13:33) [6]

Наговорили... :)
В библиотеке RxLib (вроде бы) есть какой-то компонент, считающий сумму столбца. Какой - не подскажу уже, давно с BDE не работаю.


 
Плохиш ©   (2007-03-14 13:43) [7]


> давно с BDE не работаю.

Интересно, какое отношение к этой ветке имеет BDE?


 
DimonS ©   (2007-03-14 13:55) [8]


> Интересно, какое отношение к этой ветке имеет BDE?

Сорри, применял ЭТО только в БДЕ...


 
Ega23 ©   (2007-03-14 14:01) [9]


> В библиотеке RxLib (вроде бы) есть какой-то компонент, считающий
> сумму столбца.


Не хочешь подумать, каким образом он это делает?  :)


 
Amoeba ©   (2007-03-14 14:28) [10]


> DimonS ©   (14.03.07 13:33) [6]
>
> Наговорили... :)
> В библиотеке RxLib (вроде бы) есть какой-то компонент, считающий
> сумму столбца. Какой - не подскажу уже, давно с BDE не работаю.
>

RxLib и BDE здесь совсем ни при чем. Суммы и средние по столбцам сам считает и показывает DBGridEh из библиотеки EhLib.
http://www.delphiplus.org/articles/news/2005/ehlib_4.0.html


 
DimonS ©   (2007-03-14 15:11) [11]


> Amoeba ©   (14.03.07 14:28) [10]


Точно, сейчас покопался. Именно EhLib, по старым исходникам посмотрел. В нем есть такие компоненты.


> Не хочешь подумать, каким образом он это делает?  :)

А если типа "select Sum(Ваш_столбец)"? Намного быстрее будет...
Хотя, в исходники незаглядывал...


 
Ega23 ©   (2007-03-14 15:16) [12]


> А если типа "select Sum(Ваш_столбец)"? Намного быстрее будет.
> ..
> Хотя, в исходники незаглядывал...
>


А это я уже не знаю, что там быстрее будет. Но если ты внимательно посмотришь исходники Eh, то поймёшь, как он сумму по столбцу считает.


 
Cara ©   (2007-03-14 17:34) [13]

А как в EhLib DBGridEh посчитать сумму?


 
Amoeba ©   (2007-03-14 17:56) [14]


> Cara ©   (14.03.07 17:34) [13]
>
> А как в EhLib DBGridEh посчитать сумму?

Настроить Footer. Подробнее смотри идущую в комплекте демку, а иначе долго бъяснять.


 
RASkov   (2007-03-14 18:31) [15]

Сумму значение поля не возможно посчитать не пробежавшись по каждой записи... пусть то будет своя реализация или чужая(функция, SQL...)... Имхо.
Можно сделать отдельную табличку(или файл) где хранить сумму поля.
При добавлении новой записи - увеличивать на значение поля, при удалении - уменьшать, а при изменении - перед изменением отнять старое значение после сохранения добавить новое. Но это наверное только в монопольном режиме и вообще наверное ерунда (просто мысли вслух). Ну и периодически делать проверку т.е. пробежаться по всем и сравнить....


 
zdm ©   (2007-03-14 18:49) [16]

в ehlib
FooterRowCount=1(или больше)
даблклик по гриду, добавить необходимые columns и которого надо считать сумму Footer-ValueType-fvtSum


 
Anatoly Podgoretsky ©   (2007-03-14 19:17) [17]

> Cara  (14.03.2007 11:40:02)  [2]

В Дельфи нет фукции Sum, Дельфи компилятор общего назначения, а Акцесс это СУБД



Страницы: 1 вся ветка

Текущий архив: 2007.04.08;
Скачать: CL | DM;

Наверх




Память: 0.51 MB
Время: 0.037 c
15-1173701197
Styx_
2007-03-12 15:06
2007.04.08
Преобразование RTF или DOC в PDF


15-1174058986
oldman
2007-03-16 18:29
2007.04.08
Пожелай мне удачи в бою...


1-1171322960
Makhanev Alexander
2007-02-13 02:29
2007.04.08
Разделение UI по формам...


15-1173703598
DSKalugin
2007-03-12 15:46
2007.04.08
помогите перевести на VBA


2-1174156866
Malik
2007-03-17 21:41
2007.04.08
Создание папки во время выполнения программы