Текущий архив: 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.45 MB
Время: 0.011 c