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

Вниз

Update нескольких таблиц через TIBQuery   Найти похожие ветки 

 
Pul   (2004-02-06 12:11) [0]

Есть запрос на склейку двух таблиц. В гриде все поля (за исключением связующих) должны быть редактируемыми. Каким образом с использованием TIBQuery.UpdateObject выполнить update или insert для двух таблиц. Насколько я понял, это делается в обработчике OnUpdateRecord, только как это сделать с двумя таблицами?


 
MV   (2004-02-06 12:27) [1]

Используйте TUpdateSQL, или, что более удобно, используйте компоненты IBX (или из очень дешевый - по стоимости, не покачеству - FIB+). Там есть замечательный TIBDataSet. У него определяется набор SQL - предложений на каждую операцию отдельно( Select, Insert, Update, Delete, Refresh).


 
Pul   (2004-02-06 12:47) [2]

>> MV (06.02.04 12:27) [1]
Компонент TIBQuery как раз именно из IBX, именно его я и использую, именно у него есть свойство UpdateObject, которому назначается TIBUpdateSQL, в котором и определяется набор SQL предложений на каждую операцию отдельно (Select, Insert, Update, Delete, Refresh). Меня интересует, как правильно сделать Update/Insert, если в запросе TIBQuery участвуют несколько таблиц.


 
MV   (2004-02-06 12:52) [3]

Вот, блин, действительно - смотришь в книгу - а там фига...
Извиняюсь.

Ну, по-моему, из-за того, что можно задавать только одно SQL предложение - то только через хранимые процедуры или через обновляемый View. (это когда к View цепляешь триггеры, реагирующие на Insert/update/delete)


 
Pul   (2004-02-06 13:21) [4]

А через обработчик TIBQuery.OnUpdateRecord никак нельзя?


 
MV   (2004-02-06 13:41) [5]

Что-то логика хромает, по-моему: если связь 1:1, то объедените таблицы, и все дела; а если 1:Many - что будет, если меняем в подчиненной таблице - все строски с такой связью рефрешить? Сделайте лукап - поле, а если хотим не только выбор из списка, то добавьте в него "эллипсоидную" кнопку - вызывайте редактирование в отдельной форме.

TIBQuery.OnUpdateRecord - можно в UpdateSQL какую-нибудь лажу запихать, чтобы OnUpdateRecord стрелял, но внутр обработчика делать отмену, затем запускать внешний TIBSQL, например, потом посылать форме мессагу, чтобы рефрешить набор данных. Гемор, одним словом...


 
HSolo ©   (2004-02-06 14:34) [6]

> MV (06.02.04 13:41) [5]
В общем случае - ничего не хромает :)) Может, человек строит что-то вроде:
http://www.compress.ru/Article.asp?id=2006

> Pul (06.02.04 13:21) [4]
> А через обработчик TIBQuery.OnUpdateRecord никак нельзя?
Вы имеете в виду примерно как в Delphi Help - Using multiple update objects? А чем Вам не подходит MV (06.02.04 12:52) [3] ?



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

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

Наверх




Память: 0.48 MB
Время: 0.017 c
14-6217
Думкин
2004-02-11 06:43
2004.03.03
11 февраля


14-6239
Cosinus
2004-02-07 13:55
2004.03.03
Как вы относитесь к творчеству Лукьяненко?


1-6094
Новичек
2004-02-20 23:12
2004.03.03
Генерация отчета


1-6111
DmitryNekl
2004-02-20 17:43
2004.03.03
Контекстное меню


3-5955
Lisa
2004-02-05 22:15
2004.03.03
Какие поля содержатся в результате выполнения запроса в TQuery?