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

Вниз

Суммирование данных.Ошибка в коде?   Найти похожие ветки 

 
Wiedzmin   (2006-08-26 17:23) [0]

Здравствуйте, уважаемые!

Помогите с проблемой.Объясняю:

Есть таблица table1. В ней столбец quantity. После нажатия на кнопку button1 должна быть подсчитана сумма всех чисел столбца и выведена в Edit1.

Проблема: считает совершенно не так. берет последнюю запись и умножает на число строк.

Вопрос: почему? как исправить?

Вот отрывок из листинга:
x:=0;
table1.Last;
y:=table1.FieldByName("quantity").Value;
for n:=table1.RecordCount downto 1 do x:=x+y;

edit1.Text:= inttostr(x);


 
Anatoly Podgoretsky ©   (2006-08-26 17:45) [1]

Все правильно это умножение последней строки на количество.


 
Virgo_Style ©   (2006-08-26 18:33) [2]

мы в восхищении (с)


 
Fay ©   (2006-08-26 19:25) [3]

"Вы берёте, и стреляете себе в ногу."
Это тот самый случай.


 
Desdechado ©   (2006-08-27 15:49) [4]

with(table1) do begin
First;
x:=0;
while( not EOF ) do
 begin
   x:=x+FieldByName("aaa").AsFloat;
   Next;
 end;
end;

Но через SELECT Sum(aaa) будет быстрее и правильнее


 
Wiedzmin   (2006-08-28 15:37) [5]

спасибо. рад был услышать ваше мнение


 
StriderMan ©   (2006-08-28 15:41) [6]

может как-нибудь запросиком проще? SUM?


 
SergP.   (2006-08-28 15:56) [7]

> x:=0;
> table1.Last;
> y:=table1.FieldByName("quantity").Value;
> for n:=table1.RecordCount downto 1 do x:=x+y;
>
> edit1.Text:= inttostr(x);


М-да... в 5 строках 3 ошибки...
1). Цикл for - нехорош в данном случае. Нужно while not table1.bof do
2). Нет перехода к предыдущей записи. Table1.Prior
3). В теле цикла написана херня.



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

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

Наверх




Память: 0.48 MB
Время: 0.027 c
2-1156450074
vain
2006-08-25 00:07
2006.09.17
ShellListView


15-1156408626
r@bbit
2006-08-24 12:37
2006.09.17
Основные причины Exception EInOutError


2-1157013854
worldmen
2006-08-31 12:44
2006.09.17
Компонент RX 2.75


15-1155064161
xxxx
2006-08-08 23:09
2006.09.17
дозвон


15-1156173016
SergP.
2006-08-21 19:10
2006.09.17
Кто знает как убрать банеры на сайте www.****.nm.ru ?