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

Вниз

Как в FB организовывают связь Мастер-Детал?   Найти похожие ветки 

 
КаПиБаРа ©   (2004-11-01 06:56) [0]

Набор Мастер получен в IBQuery и отображен в DBLookUp.
Набор Detail получен в IBDataSet и отображен в DBGrid.

При выборе значений в DBLookUp нужно изменять набор в DBGrid.

Как обычно это делается? У меня имеется только такая идея. Переписывать динамически запросы IBDataSet с учетом условия выбранного в DBLookUp.


 
ЮЮ ©   (2004-11-01 08:54) [1]

>Переписывать динамически запросы IBDataSet с учетом условия выбранного в DBLookUp

запрос в IBDataSet должен быть параметрическим, а если у него в качестве DataSource указать Мастер, то и получишь Мастер-Detail связь вез единой строчки кода


 
КаПиБаРа ©   (2004-11-01 10:02) [2]

А можно на примере (для тупых)?
Имеем
 object ibdsElGrup: TIBDataSet
 ...
   SelectSQL.Strings = (
     "select * from TBELGRUP"
     "where"
     "  Grup = :Grup")
 ...

и
   object ibqSposobGrupForElGrup: TIBQuery
   ...
   SQL.Strings = (
     "select * from TBSPOSGRUP")
   ...


Описание таблиц. TBSPOSGRUP
Способы группировки
Pole     Тип      Описание
IDSposGrup сетчик   Уникальный ключ
Name     20 символов Название способа группировки

Элементы группы. TBELGRUP
Pole     Тип      Описание
IDElGrup сетчик   Уникальный ключ
Name     30 символов Название группы
Grup     целое    ID способа группировки (IDSposGrup из таблицы TBSPOSGRUP)

Свойства MasterSource, MasterField у TIBDataSet нет. Как сделать Мастер-Detail?


 
Johnmen ©   (2004-11-01 10:15) [3]

>Свойства MasterSource, MasterField у TIBDataSet нет. Как сделать Мастер-Detail?

А что лень поискать, что есть ? Напр. DataSource.
WHERE DetailID=:MasterID
DetailID - ссылочное поле детальной табл.
MasterID - ключевое поле мастерной табл.


 
ЮЮ ©   (2004-11-01 11:01) [4]

select * from TBELGRUP
where
Grup = :IDSposGrup

ibdsElGrup.DataSourse = <DataSource для ibqSposobGrupForElGrup>
название параметра в Detail должно свпадать с именем в Master


 
КаПиБаРа ©   (2004-11-01 13:49) [5]

Спасибо, с отображением/изменением записей все получилось. Но не могу разобраться с вставкой данных

Insert into TBElGrup
 (IDElGrup, Name, Grup)
values
 (:IDElGrup, :NAME, :IDSposGrup)


В поле Grup всегда вставляется 0.
И еще вопрос: :IDSposGrup всегда равен значению IDSposGrup из таблицы TBSPOSGRUP, если ibqSposobGrupForElGrup прописан в DataSource ibdsElGrup.

===============================
Стою на асфальте,
Ноги в лыжи обуты.
То ли лыжи не едут,
то ли я ...
===============================


 
ЮЮ ©   (2004-11-03 04:59) [6]

Судя по коду IBCustomDataSet, обращение к DataSource  есть только в методе InternalSetParamsFromCursor, который, в свою очередь, вызывается только в InternalOpen, т.е. только при открытии набора данных.

Попробуй в инсерт вместо :IDSposGrup указать :Grup, возможно, нужная функциональность реализована ещё в TDataSet.


 
Johnmen ©   (2004-11-03 09:19) [7]

>ЮЮ ©   (03.11.04 04:59) [6]

А в чём сомнения ? DataSource для МД и предназначен и замечательно работает. Даже для IBCustomDataSet :)
И в данном случае оупен Д будет каждый раз, когда изменяются значения параметров в селектскл.


 
ЮЮ ©   (2004-11-03 11:24) [8]

>Johnmen ©   (03.11.04 09:19) [7]

C селектом проблем-то нет, проблема [5], какой параметр указать в InsertSQL, дабы подставилось значение из master-а



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

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

Наверх




Память: 0.49 MB
Время: 0.043 c
1-1100291712
Dmitry
2004-11-12 23:35
2004.11.28
Отловить закрытие процесса


11-1082825813
Max003
2004-04-24 20:56
2004.11.28
Что делать? Минимальный MCK проект(пустая форма) весит 25.5 кб


14-1100443206
Cheater
2004-11-14 17:40
2004.11.28
Забыл ссылку на сайт, где можно кинуть свою фотку и....


14-1100279610
vertal
2004-11-12 20:13
2004.11.28
Блокировка удаления exe во время его исполнения в Win NT(2000)


3-1098267203
GanibalLector
2004-10-20 14:13
2004.11.28
решение проблемы обрыва коннекта в IBX