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

Вниз

Отследить изменение поля таблицы в DBGrid   Найти похожие ветки 

 
neat   (2005-03-03 11:03) [0]

Здравствуйте Все!
Вопрос простой, но отнял у меня довольно много времени. Как отследить, изменялось ли (использую DBGrid) значение конкретного(WBD) поля. Я решил это так. Может существуют другие способы ?

procedure TForm1.DataSource1DataChange(Sender: TObject; Field: TField);
begin
If Field <> nil then begin
   If Field.FieldName = "WBD" then
   begin
     Table1["PN"]:=Table1["WBF"]-Table1["WBD"];
     Table1.Post;
   end;
end;


 
Johnmen ©   (2005-03-03 11:06) [1]

конкретное_поле.OnChange


 
ЮЮ ©   (2005-03-03 11:15) [2]

DataSource1DataChange - этот обработчик вызовется и просто при переходе с записи на запись, есле при этом значение поля Field меняется. Выкинь его из таблицы (PN), если это просто разность двух полей, и будет тебе счастье (а то ведь в таблице можно ещё поменять WBF и само PN - без твой программы - и что тогда будет?


 
neat   (2005-03-03 12:58) [3]

конкретное_поле.OnChange - ну и как это использовать ?


 
Johnmen ©   (2005-03-03 13:03) [4]

Ну и так, как написано в хелпе F1


 
ЮЮ ©   (2005-03-03 13:04) [5]

В DataSet-е вызвать Fields Editor, добавить все поля, а у поля конкретное_поле написать обработчик OnChange


 
clickmaker ©   (2005-03-03 13:05) [6]

DataSet.UpdateStatus
для текущей записи, в цикле мона проверить для всех

для конкретного поля сравни Field.Value и Field.NewValue после Post


 
neat   (2005-03-03 13:33) [7]

Fields Editor наверное хорошее решение, но ведь это создаются статические поля, мне тогда придётся весь модуль перелопачивать (он у меня не маленький).

сравни Field.Value и Field.NewValue - это если включено CachedUpdates. Простите я не знаю как это использовать. Посмотрел в Help - там есть процедуры, котрые неизвестно в каком модуле, в общем не получилось.

Ну и так, как написано в хелпе F1 - если знаешь, так и напиши, мне ответ нужен, а не намёк. Я итак времени потратил немало, ты мне предлагаешь ещё потренироваться.


 
ЮЮ ©   (2005-03-03 13:39) [8]

А почему это не воткнуть в BeforePost?

И вообще, как насчет "Выкинь его из таблицы (PN), если это просто разность двух полей, и будет тебе счастье (а то ведь в таблице можно ещё поменять WBF и само PN - без твой программы - и что тогда будет?"



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

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

Наверх




Память: 0.48 MB
Время: 0.028 c
3-1109582174
GebbelZ
2005-02-28 12:16
2005.03.27
доступность InterBase


1-1110308995
Дельфин
2005-03-08 22:09
2005.03.27
Консольные приложения


1-1110954242
Sapsi
2005-03-16 09:24
2005.03.27
массив записей


14-1109955031
Jeer
2005-03-04 19:50
2005.03.27
Эквилибриум


3-1109265922
Bogdan
2005-02-24 20:25
2005.03.27
Загрузка данных Query на форму