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

Вниз

TDatasetProvider s stuff   Найти похожие ветки 

 
pasha_golub ©   (2005-09-20 10:45) [0]

Вводная. Есть потомок TDataset - наш (почти мой ;). Пользователь желает извернуться и сделать Мастер-Детайл отображение через такую схему:


[+] PSQLDatabase1
|--- MasterTable: TPSQLTable
      |--- DSMaster: TDataSource
            |--- DetailTable: TPSQLTable


Вот тут пока знакомо, а потом идет заморочка с провайдерами и вложенными DataSet"ами.


[+] MasterTable: TPSQLTable
|--- pvdMaster: TDataSetProvider
      |--- cdsMaster: TClientDataset
            |--- cdsMasterDetailTable: TDataSetField
                  |--- cdsDetail: TClientDataSet


При чем cdsMasterDetailTable.FieldName := "DetailTable";
Я так понимаю, этой строчкой пользователь хотел сказать, что должна использоваться DetailTable. Но как это должно происходить через провайдер, для меня загадка.

Соответственно есть еще два TDbGrid"a и два TDataSource"a, с помощью которых гриды и подключаются к cdsMaster & cdsDetail. Ну, это неважно, впрочем.

В хелпе написано:
TDataSetField represents a nested dataset field in a database. This nested dataset can result from an object relational database (such as the nested datasets in Oracle 8 databases) or from a provider that packages data for the master table of a master/detail relationship.

Далее. Во время работы программы, по логу соединения видно, что данные Detail запроса тянутся, что в принипе и не удивительно. Однако, в гриде они не появляются. Не могу понять, что здесь не так.

Вопросы:

Правильна ли схема вообще построена?

Что  и как должен реализовывать потомок TDataset"a, чтобы такая схема работала (Я грешу на неверную реализацию IProviderSupport)?

Любые замечания по теме будут приняты к рассмотрению. А то глаз замылился уже, гляжу и не вижу ничего.

Спасибо


 
pasha_golub ©   (2005-09-20 14:40) [1]

Как-то что-то все молчат...

Может нужно какие детали раскрыть? Спрашивайте...


 
rayrom ©   (2005-09-20 14:55) [2]

Привет Паша, как я понял люди хотя матер-детайл в одной компаненте сделать? Мне тоже было бы интересно узнать как это реализовать!


 
pasha_golub ©   (2005-09-21 10:51) [3]

Клянуться, что через TTable у них такой финт ушами проходит.

Из хелпа я почерпнул, то видимо, провайдер должен каким-то образом на запрос TClientDataset"а вытягивать при необходимости и Детайл датасет.

Хоть убей, даже не знаю где копать.
IProviderSupport по этому поводу молчит. В хелпе лишь обрывки поверхностной инфы...


 
Rule ©   (2005-09-21 12:05) [4]

pasha_golub ©   (21.09.05 10:51) [3]
шото муть какаято ... первый раз слышу


 
pasha_golub ©   (2005-09-21 12:22) [5]


> шото муть какаято ... первый раз слышу

Аналогично. Однако дядя Борланд пишеть:

TDataSetField represents a nested dataset field in a database. This nested dataset can result from an object relational database (such as the nested datasets in Oracle 8 databases) or from a provider that packages data for the master table of a master/detail relationship.

Это я повторяюсь... Ну, да ладно. А вот как товарищ провайдер packages data...



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

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

Наверх




Память: 0.48 MB
Время: 0.053 c
2-1128600837
Sysanin
2005-10-06 16:13
2005.10.30
Переменные в функциях


2-1128037519
TechnoDreamer
2005-09-30 03:45
2005.10.30
Помогите составить запрос


2-1128492682
Серг73
2005-10-05 10:11
2005.10.30
ADO+Acess


14-1128752557
ArchValentin
2005-10-08 10:22
2005.10.30
Проблема с процем intel celeron


4-1125186966
graveyard
2005-08-28 03:56
2005.10.30
как снять атрибут с файла