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

Вниз

Как заставить DBGrid отображать изменения триггера BeforeInsert?   Найти похожие ветки 

 
TheEd   (2005-02-04 19:42) [0]

Господа, собственно subj. Если подробнее, в IB7.0 есть таблица, в которой некоторое поле F1 заполняется в триггере BeforeInsert некоторым значением X.
 Кидаем на форму IBDataBase, IBTransaction, IBTable, TDataSource, DBGrid завязываем как положено, запускаем. Вставляем новую запись в DBGrid - поле F1 <> X!
 Как сделать так, что бы в момент вставки DBGrid перечитал содержимое БД, на какое событие повеситься?

Заранее спасибо!


 
Соловьев ©   (2005-02-04 19:45) [1]


> Вставляем новую запись в DBGrid - поле F1 <> X!

используй не IBTable а IBDataSet там есть свойство RefreshSQL


 
Desdechado ©   (2005-02-04 22:16) [2]

> в момент вставки DBGrid перечитал
до или после?


 
TheEd   (2005-02-06 23:19) [3]

И 1 и 2 ответ не ясны. Может я неправильно описал трабл: я вставляю запись в DBGrid не программно, а всего лишь нажав стрелку вниз, находясь на последней записи.
И если RefreshSQL, то какой использовать?


 
TheEd   (2005-02-09 01:14) [4]

Господа, вопрос на мой взгляд пустяковый, неужто никто не поможет кратким лаконичным ответом?

(Как разберусь - сам себе отвечу :)


 
Deniz   (2005-02-09 07:26) [5]

Объясни толковее что надо.
Сначала клиент далает "у себя" INSERT, потом POST, потом клиент посылает запрос на сервер.
Далее, срабатывает триггер на сервере before insert, делается insert в таблицу, потом триггер after insert.
http://www.ibase.ru/develop.htm


 
Fareader   (2005-02-09 14:20) [6]

После того как будет Commit у транзакции нужно будет обновить НД и все изменения станут видны :)


 
TheEd   (2005-02-09 23:20) [7]

Попробую объяснить толковее: в таблицу DBGrid добавляется строка - ну к примеру DBNavigator, или нажимая стрелку вниз, находясь на последней строке. Все поля - пустые, хотя в поле ID должен сработать триггер BeforeInsert. Поясните механизм - может SQL запрос Insert посылается только тогда когда редактирование постится? Тогда как корректно отображать в новой записи то что отрабатывают тригеры, пока она в стадии редактирования???
Вроде как разжевал - повторюсь, что вопрос наверняка решается просто - нутром чую.
Прошу помощи, потому что наверняка кто-то с этим уже боролся!


 
Deniz   (2005-02-10 07:29) [8]

>TheEd   (09.02.05 23:20) [7]
> ... Все поля - пустые, хотя в поле ID должен сработать триггер BeforeInsert.

Не должен, прочитай внимательно [5].

>Тогда как корректно отображать в новой записи то что отрабатывают тригеры, пока она в стадии редактирования???

Никак, пока ты пост не сделаешь, триггер не сработает.
Ты лучше опиши не то, как ты хочешь сделать, а то как это все должно выглядеть для пользователя.


 
Deniz   (2005-02-10 07:32) [9]

>Fareader   (09.02.05 14:20) [6]
>После того как будет Commit у транзакции нужно будет обновить НД и все изменения станут видны :)

Если все изменения и чтение проходит в одной транзакции, то Commit не обязательно. Транзакция видит свои изменения.


 
TheEd   (2005-02-10 23:34) [10]

Почитал, поразмыслил, спасибо люди добрые, вижу что делать уже. Автоматом не получится - тут ясно. Прийдётся в события DataSet"а лезть (BeforePost), делать напр. SELECT к генератору, получать ID от него, и назначать поле. А в триггере на null проверять и если не null - не трогать поле.

Спасибо за поддержку!


 
Deniz   (2005-02-11 07:05) [11]

Для генератора в IBDataSet есть специальное свойство(GeneratorField), просто настрой его и все.
Да, и не пользуйся IBTable никогда. В IBDataSet есть все, что тебе потребуется.


 
Deniz   (2005-02-11 07:06) [12]

PS: Не забудь прочитать статьи на http://www.ibase.ru



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

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

Наверх




Память: 0.49 MB
Время: 0.053 c
1-1109618333
Bloody-Wolf
2005-02-28 22:18
2005.03.13
Перевод числа


9-1103448218
Goldseeker
2004-12-19 12:23
2005.03.13
Классы?


14-1109133755
begin...end
2005-02-23 07:42
2005.03.13
С Днём рождения! 23 февраля


14-1109104216
Profi
2005-02-22 23:30
2005.03.13
Посвящается DOOM e


14-1108887275
YurikGL
2005-02-20 11:14
2005.03.13
SY576