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

Вниз

Refresh TClientDataSet по Master-Detail связке   Найти похожие ветки 

 
Ega23 ©   (2006-01-31 17:56) [0]

Вкратце, ситуация такова.
Есть Мастер-запрос (TADOQuery->TDataSource). На него смотрит грид.
Есть Деталь-запрос. Причём нужно, чтобы в конечном итоге данные из Detail-запроса оказались в TCleintDataSet.
Делаю стандартную связку TADOQuery->TDataSetProvider->TClientDataSet->TDataSource.
Для деталь-запроса поле в поле DataSource прописываю TDataSouce из мастер-запроса. Всё пучком.
НО. При обновлении данных в деталь-запросе данные в TClientDataSet НЕ ОБНОВЛЯЮТСЯ (да и не должны за просто так).
Вопрос: как мне лучше обновить TClientDataSet?


 
Johnmen ©   (2006-01-31 18:00) [1]

Refresh ?


 
Ega23 ©   (2006-01-31 18:09) [2]


> Refresh ?


В том-то и дело, что нифига...  :-(
Я уже и Master-Detail заменил на вызов обработчика в MasterDataSource.OnDataChange:

procedure TGUIAccRolePropsFrame.dsAccRolesDataChange(Sender: TObject;
 Field: TField);
var
RoleID:Integer;
ss:String;
begin
 RoleID:=aqAccRoles.FieldByName("ObjID").AsInteger;
 ss:="exec  S_TAccessRole @ActNam=""ACCMETPL.SEL"","+
     " @RoleID="+ValX(RoleID);
 aqAllObjects.Close;
 aqAllObjects.SQL.Add(ss);
 aqAllObjects.Open;
 if not cdsAllObjects.Active then
   cdsAllObjects.Open
  else
   cdsAllObjects.Refresh;
end;

aqAccRoles:TADOQuery (Мастер-запрос)
aqAllObjects:TADOQuery (Detail-запрос)
cdsAllObjects:TClientDataSet


 
sniknik ©   (2006-01-31 18:14) [3]

> как мне лучше обновить TClientDataSet?
может лучше им вообще не пользоваться? при такой то связке в одном приложении.


 
Johnmen ©   (2006-01-31 18:18) [4]

>В том-то и дело, что нифига...  :-(

Т.е. TClientDataSet.Refresh нифига?


 
Ega23 ©   (2006-01-31 18:18) [5]


> Т.е. TClientDataSet.Refresh нифига?


Угу...


 
Johnmen ©   (2006-01-31 18:20) [6]

Интересная загогулина...:)


 
Johnmen ©   (2006-01-31 18:21) [7]

Close-Open?


 
Ega23 ©   (2006-01-31 18:21) [8]


> может лучше им вообще не пользоваться? при такой то связке
> в одном приложении.


Дело в том, что он мне возвращает достаточно большую "деревянную" выборку, где надо данные подготовить на клиенте, и потом одной пачкой отправить на сервер. Пользование чем-либо, типа TTable не катит, т.к. захватит таблицу в экслюзив. А свою структуру "наворачивать" - средства отображения НД не увидят изменений.


 
Ega23 ©   (2006-01-31 18:23) [9]


> Close-Open?


Да пробовал. И с разными выкрутасами, типа EmptyDataSet, и без них.
Не обновляется, скотина...


 
Johnmen ©   (2006-01-31 18:25) [10]

>Не обновляется, скотина...

Это о-о-очень странно... М.б. повнимательней код поковырять?


 
Ega23 ©   (2006-01-31 18:30) [11]


> Это о-о-очень странно... М.б. повнимательней код поковырять?


Так. Похоже это деталь-запрос не обновляется. Сейчас ещё помучаю...


 
Ega23 ©   (2006-01-31 18:41) [12]

ЕДРИТЬ ТВОИ ЛАПТИ!!!

aqAllObjects.Close;
aqAllObjects.SQL.Add(ss);
aqAllObjects.Open;


А SQL.Clear  конечно, Дядя Вася делать будет...

Тьфу, блин, на такой ерунде пол-дня потерял...


 
sniknik ©   (2006-01-31 19:57) [13]

> Дело в том, что он мне возвращает достаточно большую "деревянную" выборку, где надо данные подготовить на клиенте, и потом одной пачкой
> отправить на сервер. Пользование чем-либо, типа TTable не катит ...
"катит" пользоваться TADODataSet c установденным LockType в ltBatchOptimistic (батч апдейте режим - аналог клиентского датасета)
посмотри. всяко проще будет без "левых" длинных связок.


 
msguns ©   (2006-02-01 10:09) [14]

Мне тоже не понятно, зачем для "закачки" дерева и пакетного его обновления юзать CDS. Почему нельзя дерево держать в TList и пересоздавать его (все или начиная с соотв.узла) при перечитке детала.
А уже TList можно отображать в том же стрингриде (если, конечно, там не сотни тыщ записей) как таблицу


 
Ega23 ©   (2006-02-01 10:45) [15]


> Почему нельзя дерево держать в TList и пересоздавать его
> (все или начиная с соотв.узла) при перечитке детала.
> А уже TList можно отображать в том же стрингриде (если,
> конечно, там не сотни тыщ записей) как таблицу


Потому, что
a) На CDS смотрит DBTreeView
б) Нафига создавать дополнительные структуры, если уже готовые решения есть?
в) Ошибка была тривиальная. Всё уже прекрасно работает.


 
msguns ©   (2006-02-01 11:01) [16]

>Ega23 ©   (01.02.06 10:45) [15]

ok



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

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

Наверх




Память: 0.5 MB
Время: 0.029 c
2-1142242532
dabreezy
2006-03-13 12:35
2006.03.26
Удаление дублирующих строк из файла


3-1138953184
Alexey V.
2006-02-03 10:53
2006.03.26
Login MSACCESS


2-1141723301
Nsk3D
2006-03-07 12:21
2006.03.26
DLL


1-1140431149
VEZ
2006-02-20 13:25
2006.03.26
TActionToolBar


2-1141928354
zxcv
2006-03-09 21:19
2006.03.26
двумерный масив в ф-ии