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

Delphi Sources



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

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 04.03.2011, 11:24
beztrud beztrud вне форума
Прохожий
 
Регистрация: 04.03.2011
Сообщения: 3
Репутация: 10
По умолчанию Обработка данных

Здравствуйте. Есть база данных access, подключаюсь через ado, отображается через dbgrid. Нужно после ввода данных в определенные ячейки сделать некоторые математические операции и данные записать в другие ячейки. Написал
Код:
procedure TForm3.Button1Click(Sender: TObject);
var
v,sh:integer; //высота и ширина рамки
l:extended;//длина рамки
begin
button1.Visible:=false;
dbnavigator1.Visible:=false;
adotable1.Open;
dbgrid1.Columns[3].Visible:=true;
dbgrid1.Columns[4].Visible:=true;
dbgrid1.Columns[5].Visible:=true;
adotable1.First;
adotable1.Edit;
adotable1.RecNo:=1;
adotable1.Fields[1];
v:=adotable1.Fields[1].AsInteger-97;
adotable1.Fields[4].AsInteger:=v;
sh:=adotable1.Fields[2].AsInteger-97;
adotable1.Fields[5].AsInteger:=sh;
l:=(Adotable1.Fields[1].AsInteger+8+Adotable1.Fields[2].AsInteger+8)*2*Adotable1.Fields[3].AsInteger/1000;
adotable1.Fields[6].AsExtended:=l;
end;
Админ: Пользуемся тегами для оформления кода!

Но данный код обрабатывает только 1-ую строку, а нужно чтобы обрабатывал все заполненные строки. Помогите пожалуйста.

Последний раз редактировалось Admin, 04.03.2011 в 11:32.
Ответить с цитированием
  #2  
Старый 04.03.2011, 12:01
Аватар для Страдалецъ
Страдалецъ Страдалецъ вне форума
Гуру
 
Регистрация: 09.03.2009
Адрес: На курорте, из окна вижу теплое Баренцево море. Бррр.
Сообщения: 4,721
Репутация: 52347
По умолчанию

Надо делать не так. Вам нужно добавить в AdoTable вычисляемое поле, и в специальном событии OnCalcFields проводить нужные вычисления.
__________________
Жизнь такова какова она есть и больше никакова.
Помогаю за спасибо.
Ответить с цитированием
  #3  
Старый 04.03.2011, 12:54
Аватар для friz
friz friz вне форума
Местный
 
Регистрация: 04.04.2008
Адрес: Минск
Сообщения: 596
Версия Delphi: 2007 & JAVA EE
Репутация: 10670
По умолчанию

Код:
while not ADOTable1.Eof do
begin
........
ADOTable1.Next
end;
__________________
Последний раз редактировалось Admin, Сегодня в 10:32.
Ответить с цитированием
  #4  
Старый 07.03.2011, 14:35
beztrud beztrud вне форума
Прохожий
 
Регистрация: 04.03.2011
Сообщения: 3
Репутация: 10
По умолчанию

Цитата:
Сообщение от Страдалецъ
Надо делать не так. Вам нужно добавить в AdoTable вычисляемое поле, и в специальном событии OnCalcFields проводить нужные вычисления.
Если можно по-подробнее.
Ответить с цитированием
  #5  
Старый 07.03.2011, 14:36
beztrud beztrud вне форума
Прохожий
 
Регистрация: 04.03.2011
Сообщения: 3
Репутация: 10
По умолчанию

Цитата:
Сообщение от friz
Код:
while not ADOTable1.Eof do
begin
........
ADOTable1.Next
end;

Что-то не получается.
Ответить с цитированием
Ответ


Delphi Sources

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

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

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

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


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


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

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

ВКонтакте   Facebook   Twitter