Главная страница
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.044 c
14-1100320245
Sniper-Max
2004-11-13 07:30
2004.11.28
Програмирование под мобилы. Где взять mophun SDK?


4-1097760226
Дядя
2004-10-14 17:23
2004.11.28
Срочно - надо заблокировать клаву и мышь, Но


6-1095258006
AlexV
2004-09-15 18:20
2004.11.28
Как проверить, доступен ли комп в локальной сети?


1-1100177535
andrey__
2004-11-11 15:52
2004.11.28
TServiceApplication - Pause, Continue, Stop


9-1090874908
RyDmi
2004-07-27 00:48
2004.11.28
Для чего нужен параметр doWaitVBlank в DXDRAW?