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

Вниз

Почему при обновлении ClientDataSet   Найти похожие ветки 

 
Ega23 ©   (2005-10-31 16:25) [0]

... ему надо заново задавать провайдера?
В ран-тайме создаю ADOQuery, DataSetProvider, ClientDataSet и DataSource.
При попытке обновления данных без задания провайдера (жирным) вылезает эксепшн "Missing data provider or data packet"


type
 TForm1 = class(TForm)
   aDBGrid: TDBGrid;
   Button1: TButton;
   procedure FormCreate(Sender: TObject);
   procedure Button1Click(Sender: TObject);
 private
   { Private declarations }

   procedure CreateAll;
   procedure Refresh;
 public
   { Public declarations }
   aQuery:TADOQuery;
   aDS:TDataSource;
   aCDS:TClientDataSet;
   aDSP:TDataSetProvider;
 end;

var
 Form1: TForm1;

implementation

{$R *.DFM}

procedure TForm1.CreateAll;
var
aSQL:String;
begin
KdrDBConnection:=TKdrDBConnection.Create;
KdrDBConnection.ConnectKdr("dbsrv2", "arm2");

aSQL:="Select * from Classes";
aQuery:=TADOQuery.Create(Self);
aQuery.SQL.Text:=aSQL;

aDSP:=TDataSetProvider.Create(Self);
aDSP.DataSet:=aQuery;

aCDS:=TClientDataSet.Create(Self);
aCDS.SetProvider(aDSP);

aDS:=TDataSource.Create(Self);
aDS.DataSet:=aCDS;

aDBGrid.DataSource:=aDS;

KdrDBConnection.ConnectQueries(Self);

end;

procedure TForm1.FormCreate(Sender: TObject);
begin
 CreateAll;
end;

procedure TForm1.Button1Click(Sender: TObject);
begin
 Refresh;
end;

procedure TForm1.Refresh;
begin
 if aCDS.Active then
  begin
   aCDS.EmptyDataSet;
   aCDS.Close;
  end;

 aQuery.Close;
 aQuery.Open;
 aCDS.SetProvider(aDSP);
 aCDS.Open;
end;



 
Johnmen ©   (2005-10-31 16:33) [1]

Потому, что читать Note из SetProvider + F1


 
Ega23 ©   (2005-10-31 16:35) [2]


> Потому, что читать Note из SetProvider + F1


Да я прочитал. Скажем так, мне непонятно зачем так сделано?
Насколько я понимаю, менять провайдера на ActiveChanged - всё равно, что Connection каждый раз для TADOQuery задавать.

Т.е. какова была мотивация при создании TClientDataSet?


 
Johnmen ©   (2005-10-31 16:50) [3]

Видимо, потому, что источник данных для провайдера в общем случае может претерпеть изменения. И SetProvider критичен к этому......
Я бы прописал "однократно" ProviderName для CDS.


 
Ega23 ©   (2005-10-31 16:54) [4]


> Видимо, потому, что источник данных для провайдера в общем
> случае может претерпеть изменения. И SetProvider критичен
> к этому......
> Я бы прописал "однократно" ProviderName для CDS.


Я в конечном итоге так и сделал.
Просто не совсем ясно, для чего был выбран такой странный путь с провайдером...


 
Johnmen ©   (2005-10-31 16:58) [5]

Мне тоже не ясно...:)
Хотя смутные мысли есть по прочтении хелпа...


 
Ega23 ©   (2005-10-31 17:01) [6]


> Я в конечном итоге так и сделал.
> Просто не совсем ясно, для чего был выбран такой странный
> путь с провайдером...
>


Не, так нельзя. Owner должен совпадать у провайдера и у CDS. А в моём случае они могут быть разные...

Ладно, буду каждый раз провайдер задавать.


 
Johnmen ©   (2005-10-31 17:13) [7]

>Не, так нельзя. Owner должен совпадать у провайдера и у CDS. А в моём
>случае они могут быть разные...

Хм... Ну и что?
Пропиши с учётом разных овнеров.



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

Форум: "Базы";
Текущий архив: 2005.12.18;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.46 MB
Время: 0.016 c
14-1132869707
TStas
2005-11-25 01:01
2005.12.18
А стоит за С++ браться, если на дельфи всего несколько месяцев ..


2-1133518721
msgipss
2005-12-02 13:18
2005.12.18
как можно использовать наследование TService


2-1133357948
Новичек
2005-11-30 16:39
2005.12.18
Небольшой вопрос относительно функции function recv.


10-1109556397
msgipss
2005-02-28 05:06
2005.12.18
Создание надстройки над Excell


1-1132148032
STRINGGRID
2005-11-16 16:33
2005.12.18
setka StringGrida





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский