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

Вниз

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

Наверх





Память: 0.45 MB
Время: 0.008 c
3-5951
Evgen
2004-02-06 06:46
2004.03.03
Codepage 866


1-6146
novi
2004-02-21 18:54
2004.03.03
Как удалить пробелы


14-6208
Style
2004-02-10 15:52
2004.03.03
Stack Overflow при компиляции 8)


1-6009
Riant
2004-02-19 16:29
2004.03.03
Delphi 6 <> Delphi 7


9-5935
Flyer
2003-08-18 13:58
2004.03.03
Проверка звука





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский