線上訂房服務-台灣趴趴狗聯合訂房中心
發文 回覆 瀏覽次數:2840
推到 Plurk!
推到 Facebook!

請教有關 ClientDataSet Read-only 的問題

缺席
mflyy
初階會員


發表:3
回覆:44
積分:44
註冊:2002-08-13

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-11-09 15:20:16 IP:211.20.xxx.xxx 未訂閱
請教各位大大,有關 ClientDataSet Read-only 的問題  (Delphi7+MS SQL 2000) 問題如下:  AdoQuery 的 SQL 內容是
 SELECT ACNO7,ACNAME7,AC_CBAL=SUM(AC_CBAL),AC_DBAL=SUM(AC_DBAL)
FROM ACCKD793 A LEFT JOIN ACCSUB93 B ON A.ACNO7 = B.AC_SUBNO
GROUP BY ACNO7,ACNAME7 
我現在希望用一個ClientDataSet 將此ADOQuery1的DataSet 存起來,其中 AC_CBAL,AC_DBAL 在ADOQury1 中是readonly,但是我希望能更新它,因為報表有用到,(當然是不要更新原有SQL上的資料) 我在ClientDataSet FieldDefine 更改設定AC_CBAL及AC_DBAL READONLY => False 可是當我在程式中Update新值時,它會出現'Try to modify read-only field'的錯誤,請教各位大大,是否我在什麼地方的屬性未設定正確? 還是ClientDataSet一定會根據它Source DataSet 的屬性而無法變更? 請各位幫忙回答一下,Thanks
P.D.
版主


發表:603
回覆:4038
積分:3874
註冊:2006-10-31

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-11-09 22:16:24 IP:61.71.xxx.xxx 未訂閱
不知道你的ClientDataSet 是如何建立出來的, 如果是以下做法 1.利用 Assign Local Data 方式把 ADO的Dataset給拉進來的話, 自然原ADO屬 性為何, cds就會保留這樣的屬性 2.將拉進來的stru, 在 FieldDefine 的properity 上找到 readonly的field改 為False 3.重新 Save to File 儲存 4.欲使用時, 請執行 ClientDataSet1.filename:= 'xxxx.cds'; 這樣應可解決readonly問題!
mflyy
初階會員


發表:3
回覆:44
積分:44
註冊:2002-08-13

發送簡訊給我
#3 引用回覆 回覆 發表時間:2004-11-09 23:22:54 IP:203.70.xxx.xxx 未訂閱
P.D 謝謝你的回應 我現在是先寫一個比較單純的環境先測試ClientDataSet的用法 因為之前我是都以SQL 的TempFile 來處理這些問題,只是在Ktop看到很多文章都是使用ClientDataSet來處理,希望你不吝指教 !!    我現在是以一個 AdoQuery1,一個DataSetProvider1,一個ClientDataSet1 於程式中產生ClientDataSet,另外用二個DBGrid來測試    於設計階段 AdoQuery1 的 SQL 內容是 SELECT ACNO7,ACNAME7,AC_CBAL=SUM(AC_CBAL),AC_DBAL=SUM(AC_DBAL) FROM ACCKD793 A LEFT JOIN ACCSUB93 B ON A.ACNO7 = B.AC_SUBNO GROUP BY ACNO7,ACNAME7    DataSetProvider1->DataSet = AdoQuery1 ClientDataSet1->ProviderName=DataSetProvider1 然後在 ClientDataSet FieldDefine 更改設定AC_CBAL及AC_DBAL READONLY 為 false  程式部分
unit Unit1;    interface    uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, DB, Grids, DBGrids, StdCtrls, ADODB, Provider, DBClient;    type
  TForm1 = class(TForm)
    ADOConnection1: TADOConnection;
    ClientDataSet1: TClientDataSet;
    DataSetProvider1: TDataSetProvider;
    ADOQuery1: TADOQuery;
    Button1: TButton;
    DBGrid1: TDBGrid;
    DBGrid2: TDBGrid;
    DataSource1: TDataSource;
    DataSource2: TDataSource;
    ClientDataSet1ACNO7: TStringField;
    ClientDataSet1ACNAME7: TStringField;
    ClientDataSet1AC_CBAL: TBCDField;
    ClientDataSet1AC_DBAL: TBCDField;
    procedure Button1Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;    var
  Form1: TForm1;    implementation    {$R *.dfm}    procedure TForm1.Button1Click(Sender: TObject);
begin
  ADOQuery1.Open();
  ClientDataSet1.Open();   好像是因為這裹會reload define 
  ClientDataSet1AC_CBAL.ReadOnly:=false;  這裹沒作用 
  ClientDataSet1AC_DBAL.ReadOnly:=false;
end;    end.
另外我有去測試你建議的方法
procedure TForm1.Button1Click(Sender: TObject);
begin
  ADOQuery1.Open();
  ClientDataSet1.Open();
  ClientDataSet1AC_CBAL.ReadOnly:=false;
  ClientDataSet1AC_DBAL.ReadOnly:=false;
  ClientDataSet1.SaveToFile('c:\test.cds');
  ClientDataSet1.Close();
  ClientDataSet1.LoadFromFile('c:\test.cds');
end;
不過好像是一樣的結果,請問一下如果依目前的作法,應如何修改呢? 最後我在多次測試發現好像是要從ADOQUERY1的 FieldDEF 去改AC_CBAL及AC_DBAL 的ReadOnly 為False,結果就可修改值了, 這樣的作法是不是很奇怪呢?
Chance36
版主


發表:31
回覆:1033
積分:792
註冊:2002-12-31

發送簡訊給我
#4 引用回覆 回覆 發表時間:2004-11-10 03:56:30 IP:203.204.xxx.xxx 未訂閱
mflyy 你好    試試把 DataSetprovider.Constrains := False; //預設為True ; 當ClientDataSet透過DataSetProvider取資料時,預設會將DataSetProvider.DataSet的相關制約(限制)條件,同時傳送給ClientDataSet,所以在ClientDataSet就會繼承AdoQuery的欄位限制條件(包括ReadOnly),因此把DataSetprovider.Constrains設為False時,DataSetProvider就不會將ADoQuery的限制條件傳送給ClientDataSet,也就可以自由的使用查詢出來的資料了,唯一要注意的就是這樣的資料可能無法(或是很麻煩)更新回資料庫囉。 另外DataSetProvider.Options有個屬性[poIncFieldProps] ,傳送出去的封包是否包含欄位的相關屬性,也可以參考一下。 Help 說明如下 poIncFieldProps The data packet includes the following field properties (where applicable): Alignment, DisplayLabel, DisplayWidth, Visible, DisplayFormat, EditFormat, MaxValue, MinValue, Currency, EditMask, DisplayValues _______________________________________ 深藍的魚,祝您好運..........連連
mflyy
初階會員


發表:3
回覆:44
積分:44
註冊:2002-08-13

發送簡訊給我
#5 引用回覆 回覆 發表時間:2004-11-10 13:57:03 IP:211.20.xxx.xxx 未訂閱
Chance36 你好,謝謝你的回應    我有試著把DataSetprovider.Constrains := False; //預設為True ; 不過還是會出現Read-Only的錯誤,這個地方似乎沒有有如Help所說的方式 最後我是用修改原先ADOQuery1的定義後,再去Open ClientDataSet 結果這樣己符合我的需求!!
procedure TForm1.Button1Click(Sender: TObject);
begin
   ADOQuery1.Open();
   ADOQuery1AC_CBAL.ReadOnly:=false;
   ADOQuery1AC_DBAL.ReadOnly:=false;
   ClientDataSet1.Open();
end;
謝謝你的回應!!
系統時間:2024-06-17 9:02:41
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!