Главная страница
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.087 c
6-1105337093
!Cyber
2005-01-10 09:04
2005.03.13
Примеры работы с Leadtools


1-1109670855
ser35
2005-03-01 12:54
2005.03.13
И опять отсчет...


11-1092757042
ecm
2004-08-17 19:37
2005.03.13
2Kladov : Bug Fix OnIdle?


3-1108024003
REA
2005-02-10 11:26
2005.03.13
SQL Запрос


1-1109231329
SergeyKU
2005-02-24 10:48
2005.03.13
Запуск любых приложений из-под Делфи