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

Вниз

работа TQuery.OnUpdateRecord   Найти похожие ветки 

 
Вольный Стрелок   (2003-12-12 11:16) [0]

Не пойму в чем дело: судя по описанию, этот обработчик должен вызываться для каждой модифицированной записи. Так и происходит.
Вот только текущая запись в передаваемом ему параметром DataSet"е не меняется.
Как же определить, какую запись обрабатывать?


 
Sandman25 ©   (2003-12-12 11:20) [1]

Смотрите DataSet.FieldByName(..).OldValue и NewValue


 
Вольный Стрелок   (2003-12-12 11:24) [2]

я имел ввиду номер текущей записи - не меняется


 
Sandman25 ©   (2003-12-12 11:28) [3]

Не надо идентифицировать данные по номеру записи. У Вас в данных нет уникального ключа?


 
Вольный Стрелок   (2003-12-12 11:32) [4]

Я по нему и смотрю.
И на всех записях он одинаковый. Это в тупик и ставит.


 
Sandman25 ©   (2003-12-12 11:34) [5]

CashedUpdates = True?
Вызываете ApplyUpdates?


 
Вольный Стрелок   (2003-12-12 11:40) [6]

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


 
Sandman25 ©   (2003-12-12 11:42) [7]

Странно. Попробуйте поставить Use Debug DCU и потрассировать.


 
Вольный Стрелок   (2003-12-12 16:35) [8]

Спасибо. Понял, в чем была причина.
Действительно, надо обращаться к полям через OldValue и NewValue.
А обращение через DataSet.Fields[ 0 ]. AsInteger, например, ведет к описанной ситуации. Хотя почему ведет, не знаю :(


 
Sandman25 ©   (2003-12-12 18:13) [9]

[8] Вольный Стрелок (12.12.03 16:35)

Дело в том, что для UpdateRecord создается новый Dataset, а не используется существующий. В этом новом DataSet находятся копии только тех записей, которые добавлялись/изменялись/удалялись. Но, в общем, Вы уже и сами разобрались :)



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

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

Наверх




Память: 0.48 MB
Время: 0.024 c
9-25178
Дмитрий К.
2003-06-20 16:55
2004.01.09
Сохранение изображения текущей сцены OpenGL


14-25531
VEG
2003-12-16 00:55
2004.01.09
Есть ли у вас мечта?


4-25659
Dido
2003-11-08 05:25
2004.01.09
Как узнать заголовок активного окна?


14-25604
Nick-From
2003-12-19 13:29
2004.01.09
sophisticated DBcombobox


14-25558
lipskiy
2003-12-15 02:04
2004.01.09
Эмулятор принтера?