Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2006.06.11;
Скачать: [xml.tar.bz2];

Вниз

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;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.45 MB
Время: 0.011 c
2-1148204287
Delphin06
2006-05-21 13:38
2006.06.11
Как сделать окно одинаковое на всех мониторах


15-1148034709
saxon
2006-05-19 14:31
2006.06.11
Задачка про гномов


2-1148497893
S@shka
2006-05-24 23:11
2006.06.11
Ошика программы при старте под XP


4-1142791086
Alex_PP
2006-03-19 20:58
2006.06.11
Как преоброзовать HWND в String ?


2-1148304847
Gagarin_MSX
2006-05-22 17:34
2006.06.11
Как циклически проследить выполнение?





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский