全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:2327
推到 Plurk!
推到 Facebook!

动态建立ClientDataSet和动态建立字段

答題得分者是:Fishman
DKSoftCHS
一般會員


發表:5
回覆:13
積分:3
註冊:2004-07-24

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-08-04 16:31:56 IP:218.14.xxx.xxx 未訂閱
下面是我的代码 CdsMain := TClientDataSet.Create(Self); CdsMain.RemoteServer := FDM_BASE.SocketConnection; CdsMain.AfterInsert := CdsMainAfterInsert; CdsMain.Name := 'CdsMain'; CdsMain.ProviderName := 'DspBsCustCode'; CdsMain.PacketRecords := 50; with CdsMain.FieldDefs.AddFieldDef do begin DataType := ftGuid; Required := true; Name := 'FID'; Size := 38; end; with CdsMain.FieldDefs.AddFieldDef do begin DataType := ftString; Name := 'FCode'; Size := 25; end; CdsMain.CreateDataSet; CdsMain.Open(); 当我打开CdsMain时,CdsMain.RecordCount始终为0,即然里面有记录 如果就是下面代码 CdsMain := TClientDataSet.Create(Self); CdsMain.RemoteServer := FDM_BASE.SocketConnection; CdsMain.AfterInsert := CdsMainAfterInsert; CdsMain.Name := 'CdsMain'; CdsMain.ProviderName := 'DspBsCustCode'; CdsMain.PacketRecords := 50; CdsMain.Open; 这样就正常的 请教各位前辈,谢谢 發表人 - DKSoftCHS 於 2004/08/04 16:50:00
jieshu
版主


發表:42
回覆:894
積分:745
註冊:2002-04-15

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-08-04 16:45:55 IP:203.204.xxx.xxx 未訂閱
引言: 下面是我的代码 CdsMain := TClientDataSet.Create(Self); CdsMain.AfterInsert := CdsMainAfterInsert; CdsMain.Name := 'CdsMain'; CdsMain.ProviderName := 'DspBsCustCode'; CdsMain.PacketRecords := 50; with CdsMain.FieldDefs.AddFieldDef do begin DataType := ftGuid; Required := true; Name := 'FID'; Size := 38; end; with CdsMain.FieldDefs.AddFieldDef do begin DataType := ftString; Name := 'FCode'; Size := 25; end; CdsMain.CreateDataSet; CdsMain.Open(); 当我打开CdsMain时,CdsMain.RecordCount始终为0,即然里面有记录 请教各位前辈,谢谢
你都沒新增資料, 也沒下CommandText取資料, 當然RecordCount都會是0. <iFrame src="http://www.coss.com.tw/jieshu/sign.htm" width=400 height=105 scolling="NO" border="0"></iFrame> 廣告一下: http://www.971.idv.tw/
------
人生有夢,逐夢而行
人若為善,福雖未至,禍已遠離
人若為惡,禍雖未至,福已遠離
http://www.taconet.com.tw/jieshu/
Fishman
尊榮會員


發表:120
回覆:1949
積分:2163
註冊:2006-10-28

發送簡訊給我
#3 引用回覆 回覆 發表時間:2004-08-04 17:00:38 IP:210.65.xxx.xxx 未訂閱
Hi DKSoftCHS,
procedure TForm1.Button1Click(Sender: TObject);
var
  CdsMain : TClientDataSet;
begin
  CdsMain := TClientDataSet.Create(Self);
  CdsMain.AfterInsert := CdsMainAfterInsert;
  CdsMain.Name := 'CdsMain';
  CdsMain.ProviderName := 'DataSetProvider1';
  CdsMain.PacketRecords := 50;
  with CdsMain.FieldDefs.AddFieldDef do
    begin
      DataType := ftGuid;
      Required := true;
      Name := 'FID';
      Size := 38;
    end;
  with CdsMain.FieldDefs.AddFieldDef do
    begin
      DataType := ftString;
      Name := 'FCode';
      Size := 25;
    end;
//  CdsMain.CreateDataSet; Disable this command
  CdsMain.Open();
  showmessage(Inttostr(CdsMain.RecordCount));
end;
---------------------------------- 小弟才疏學淺,若有謬誤尚請不吝指教 ----------------------------------
------
Fishman
DKSoftCHS
一般會員


發表:5
回覆:13
積分:3
註冊:2004-07-24

發送簡訊給我
#4 引用回覆 回覆 發表時間:2004-08-04 17:07:45 IP:218.14.xxx.xxx 未訂閱
引言: 你都沒新增資料, 也沒下CommandText取資料, 當然RecordCount都會是0.
谢谢您的回答, 在中间层 DspBsCustCode对应的adoCustCode已经写了CommandText:='SELECT * FROM bsCustCode'; bsCustCode表里已经存在一条记录。 我加上CdsMain.CommandText:='SELECT * FROM bsCustCode';也不行 如果就是下面代码 CdsMain := TClientDataSet.Create(Self); CdsMain.RemoteServer := FDM_BASE.SocketConnection; CdsMain.AfterInsert := CdsMainAfterInsert; CdsMain.Name := 'CdsMain'; CdsMain.ProviderName := 'DspBsCustCode'; CdsMain.PacketRecords := 50; CdsMain.Open; 这样就正常的
DKSoftCHS
一般會員


發表:5
回覆:13
積分:3
註冊:2004-07-24

發送簡訊給我
#5 引用回覆 回覆 發表時間:2004-08-04 17:13:34 IP:218.14.xxx.xxx 未訂閱
引言:
procedure TForm1.Button1Click(Sender: TObject);
var
  CdsMain : TClientDataSet;
begin
  CdsMain := TClientDataSet.Create(Self);
  CdsMain.AfterInsert := CdsMainAfterInsert;
  CdsMain.Name := 'CdsMain';
  CdsMain.ProviderName := 'DataSetProvider1';
  CdsMain.PacketRecords := 50;
  with CdsMain.FieldDefs.AddFieldDef do
    begin
      DataType := ftGuid;
      Required := true;
      Name := 'FID';
      Size := 38;
    end;
  with CdsMain.FieldDefs.AddFieldDef do
    begin
      DataType := ftString;
      Name := 'FCode';
      Size := 25;
    end;
//  CdsMain.CreateDataSet; Disable this command
  CdsMain.Open();
  showmessage(Inttostr(CdsMain.RecordCount));
end;
谢谢您回答 如果不使用那一句,那我上面建立的字段就没有什么用了。显示的所有的字段。
Fishman
尊榮會員


發表:120
回覆:1949
積分:2163
註冊:2006-10-28

發送簡訊給我
#6 引用回覆 回覆 發表時間:2004-08-04 17:37:16 IP:210.65.xxx.xxx 未訂閱
Hi DKSoftCHS,    ClientdataSet.CreateDataSet;  Delphi 中說明如下 Creates a new, empty client dataset. 所以 CdsMain.RecordCount = 0 因此建議你 1.捨棄 ClientDataSet 中自訂欄位,直接由 DataSet 中繼承 2.於 DataSet 中,事先定義好你所需要的欄位 ---------------------------------- 小弟才疏學淺,若有謬誤尚請不吝指教 ----------------------------------
------
Fishman
DKSoftCHS
一般會員


發表:5
回覆:13
積分:3
註冊:2004-07-24

發送簡訊給我
#7 引用回覆 回覆 發表時間:2004-08-04 18:43:09 IP:218.14.xxx.xxx 未訂閱
引言: Hi DKSoftCHS, ClientdataSet.CreateDataSet; Delphi 中說明如下 Creates a new, empty client dataset. 所以 CdsMain.RecordCount = 0 因此建議你 1.捨棄 ClientDataSet 中自訂欄位,直接由 DataSet 中繼承 2.於 DataSet 中,事先定義好你所需要的欄位 ---------------------------------- 小弟才疏學淺,若有謬誤尚請不吝指教 ---------------------------------- < face="Verdana, Arial, Helvetica"> 谢谢Fishman 的指点,使我大悟,现在已经可以了,谢谢。
系統時間:2024-04-20 10:28:45
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!