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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 24.01.2010, 15:30
m.medvedb m.medvedb вне форума
Прохожий
 
Регистрация: 24.01.2010
Сообщения: 6
Репутация: 10
По умолчанию Dbgrid....

Таблица Paradox...В DBgrid есть столбец LENGHT надо вычислить его сумму в компоненте Edit...подскажите как?
Ответить с цитированием
  #2  
Старый 24.01.2010, 16:17
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Есть три решения:
1.Сделать вычисляемый столбец типа агрегат, но это делается через ClientDataSet
2.Выполнить SQL-запрос с агрегатом
3.Обойти ручками в цикле датасет
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #3  
Старый 24.01.2010, 16:18
lmikle lmikle вне форума
Модератор
 
Регистрация: 17.04.2008
Сообщения: 8,035
Версия Delphi: 7, XE3, 10.2
Репутация: 49089
По умолчанию

Варианты:
1. Отдельным запросом
Код:
select sum(length) from table_name
2. "Пробежаться" по выборке и просуммировать.
Код:
var
  B : Pointer;
  S : Integer;
begin
  Query1.DisableControls;
  B := Query1.GetBookmark;
  Try
    Query1.First;
    S := 0;
    While Not Query1.Eof Do
      Begin
        S := S + Query1.FieldByName('length').AsInteger;
        Query1.Next;
      End;
    Query1.GotoBookmark(B);
    Query1.FreeBookmark(B);
  Finally
    Query1.EnableControls;
  End;
end;
Ответить с цитированием
  #4  
Старый 25.01.2010, 10:52
m.medvedb m.medvedb вне форума
Прохожий
 
Регистрация: 24.01.2010
Сообщения: 6
Репутация: 10
По умолчанию

Цитата:
Сообщение от lmikle
Варианты:
1. Отдельным запросом
Код:
select sum(length) from table_name
2. "Пробежаться" по выборке и просуммировать.
Код:
var
  B : Pointer;
  S : Integer;
begin
  Query1.DisableControls;
  B := Query1.GetBookmark;
  Try
    Query1.First;
    S := 0;
    While Not Query1.Eof Do
      Begin
        S := S + Query1.FieldByName('length').AsInteger;
        Query1.Next;
      End;
    Query1.GotoBookmark(B);
    Query1.FreeBookmark(B);
  Finally
    Query1.EnableControls;
  End;
end;

А в какое событие DBGrid надо добавлять код, что-бы при добавление новой записи происходил пересчет?
Ответить с цитированием
  #5  
Старый 25.01.2010, 11:49
m.medvedb m.medvedb вне форума
Прохожий
 
Регистрация: 24.01.2010
Сообщения: 6
Репутация: 10
По умолчанию

Все разобрался тема закрыта....!
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter