Главная страница
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.033 c
2-1141764975
al_1983
2006-03-07 23:56
2006.03.26
Копирование текста из WebBrowser


9-1126551988
4ECHOK
2005-09-12 23:06
2006.03.26
DWS скрипты в играх.


3-1138702466
Huk
2006-01-31 13:14
2006.03.26
ClientDataSet


2-1142067592
kkostik
2006-03-11 11:59
2006.03.26
Определить имя устройства!


15-1141621833
Новичоккк
2006-03-06 08:10
2006.03.26
Ассемблер