Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2006.03.26;
Скачать: [xml.tar.bz2];

Вниз

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;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.48 MB
Время: 0.043 c
6-1134651981
(CHALING 32)S K i N E R
2005-12-15 16:06
2006.03.26
Голосовой чат!


2-1141914459
oleg__
2006-03-09 17:27
2006.03.26
TRxFolderMonitor


2-1141751190
Эля
2006-03-07 20:06
2006.03.26
минимизация многооконного приложения


1-1140468635
Blitz
2006-02-20 23:50
2006.03.26
Delphi & Assembler


2-1141893206
nsk3d
2006-03-09 11:33
2006.03.26
Экспорт в DLL





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский