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

Вниз

По поводу процедуры "BeforePost" в Ttable   Найти похожие ветки 

 
Heretic ©   (2004-09-09 15:21) [0]

Есть две таблицы. При изменении одной таблицы необходимо произвести изменения в другой таблице.
Делаю так:

В Table1 "AfterEdit" пишу:

Begin
 OldValue:=table1.fieldvalues["Pole1"];
end;


В Table1 "BeforePost" пишу:

Begin
 if OldValue<>table1.fieldvalues["Pole1"] then
 begin
   table2.filter:="Pole1="""+vartostr(OldValue)+"""";
   table2.first;
   while not table2.eof do
   begin
     table2.edit;
     table2.fieldvalues["Pole1"]:=table1.fieldvalues["Pole1"];
     table2.post;
   end;
 end;
end;


При выполнении процедуры Table1 "BeforePost" в Table2 изменяется только первая запись, затем выдает ошибку "KeyViolations"
При повторном выполнении процедуры Table1 "BeforePost" в Table2 изменяется следующая запись, затем опять выдает ошибку "KeyViolations". Таким образом обрабатывается только одна запись Table2.

Уважаемые Гуру, что я делаю не так?


 
Ditrix ©   (2004-09-09 15:32) [1]

забыл table2.next;


 
Heretic ©   (2004-09-09 15:37) [2]

Я не забыл.
Просто разницы нет. У меня стоит фильтр на Table2 по полю "Pole1", и при выполнении "Table2.Post" Table2.RecordCount автоматически уменьшается на одну запись, так как измененная запись уже не попадает под фильтр.
Но даже если использовать table2.next - ошибка та же.


 
megabyte ©   (2004-09-09 16:33) [3]

А если попробовать, не знаю, поможет ли обновление,
table2.refresh



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

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

Наверх




Память: 0.47 MB
Время: 0.046 c
1-1096129122
Aspi
2004-09-25 20:18
2004.10.10
Поиск текста в текстовом файле...


1-1095753144
roma
2004-09-21 11:52
2004.10.10
kataloq


14-1095785261
Ломброзо
2004-09-21 20:47
2004.10.10
Вакансия


3-1095085592
yaric
2004-09-13 18:26
2004.10.10
Работа с формулами


4-1094125421
HeKTO
2004-09-02 15:43
2004.10.10
Проблемы с рисованием на окнах