Главная страница
    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.012 c
2-1132786540
Дева
2005-11-24 01:55
2005.12.18
CommaText


2-1133602150
kop
2005-12-03 12:29
2005.12.18
Свойство


3-1130935650
Александр_н
2005-11-02 15:47
2005.12.18
Создание таблиц с помощью IBSQL


2-1133269838
JTAG
2005-11-29 16:10
2005.12.18
Ув коллеги не будете ли вы так сказочно добры подсказать мне


2-1133754766
Veter
2005-12-05 06:52
2005.12.18
Как можно получить текст с поля Edit другой программы





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