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

Вниз

TIBDataSet.Refresh   Найти похожие ветки 

 
Vasilisk   (2006-04-20 00:18) [0]

Delphi 7. Interbase 6.1

Есть TIBDataSet. В котором свойства выглядит так
SelectSQL
SELECT
 ID,
 field1,
 field2,
 field3
FROM
 VW_VIEW

ModifySQL
SELECT
 ID,
 field1,
 field2,
 field3
FROM
 VW_VIEW
WHERE
 ID = :old_id

InsertSQL
EXECUTE PROCEDURE sp_e_ins(
 :field1
)

Идея следующая:
 ID и field3 заполняются в тригере (один по генератору, а второй как Now), а field2 джойнится во вьюхе из другой таблицы по полю field1.

Есть DBGrid (ReadOnly), связанный с этим датасетом, а кроме этого есть такой кусок кода
DataSet.Insert;
DataSet.FieldByName("field1").AsInteger := Val;
DataSet.Post;

Так вот, после этого в Grid"е добавляется одна запись где заполнено только поле field1.

Вызов Refresh после Post не имеет результата. Перенос генератора с сервера на клиент не желательна, но тоже не приносит никакой пользы. Единственное, что помогает - Close/Open, но это неправильно, т.к. в датасете может быть порядка 10 тысяч записей.

Что делать, чтобы заставить Refresh работать?

PS Все происходит в одной транзакции. Вызов между Post и Refresh CommitRetaining тоже не спасает.


 
Johnmen ©   (2006-04-20 09:16) [1]

Так это происходит потому, что рефрешу неоткуда взять значение ключа для обновления одной записи. Кстати, а где сам РефрешСКЛ???
Поэтому грамотный выход - получить значение генератора джля ID, а потом вставить его в инсерте.



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

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

Наверх




Память: 0.47 MB
Время: 0.033 c
9-1131295547
Friendship
2005-11-06 19:45
2006.06.11
Помогите пожалуйста разрешить одну проблему


15-1148024063
McSimm
2006-05-19 11:34
2006.06.11
Пароль уже занят, выберите другой


15-1147625369
Сумашедший художник
2006-05-14 20:49
2006.06.11
А вы говорите Фотошоп...


15-1147762283
Шутник
2006-05-16 10:51
2006.06.11
Обоснование выбора: СУБД vs файлы


2-1148531797
vidiv
2006-05-25 08:36
2006.06.11
Дайте пожалуйста простой пример работы