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

請問DBGrid此感知元件是否設定不作即時更新資料庫動作。

尚未結案
t0288542
中階會員


發表:216
回覆:254
積分:94
註冊:2004-10-06

發送簡訊給我
#1 引用回覆 回覆 發表時間:2005-08-09 10:17:46 IP:61.221.xxx.xxx 未訂閱
請問各位高手, 感知元件DBGrid通常和ADOQuery作配合,所以,每次當 執行ADOQuery.Insert或Edit或Delete等異動動作, 將會即常作更改資料庫,請問DBGrid或其他感知元作在 使用時是否可以不先作更改資料庫等使用者確定正確作 儲存或即時放棄呢. 或者又要利用另建一個暫存檔那如何與DBGrid作配合呢. 請大家給我一些意見或者有什麼好方法. 謝謝
jeff377
初階會員


發表:9
回覆:60
積分:33
註冊:2004-08-10

發送簡訊給我
#2 引用回覆 回覆 發表時間:2005-08-09 10:49:11 IP:61.66.xxx.xxx 未訂閱
你應該要使用離線的DataSet,基本上DataSet的值有辨法寫回資料庫,是因為有Connection所致,你只要將DataSet的Connection設為nil,就會成為離線的DataSet,而DataSet的異動就不會寫回資料庫了。    
  ADOQuery.Connection:= nil;  
deity
尊榮會員


發表:90
回覆:876
積分:678
註冊:2003-05-09

發送簡訊給我
#3 引用回覆 回覆 發表時間:2005-08-09 10:56:25 IP:218.15.xxx.xxx 未訂閱
t0288542您好: 可以采用ADO的BatchUpdate方式,客户端所有的修改数据先暂时储存在客户端的缓存中,而不是立刻更新回数据源中,当客户端决定要把所有的修改更新回数据源时,才做更新。您可在站内查找“BatchUpdate”关键字,有很多相关的咨询。 另可参考: http://delphi.ktop.com.tw/topic.php?topic_id=70798 http://delphi.ktop.com.tw/topic.php?topic_id=45748 试试看 <> ============================ 为什么经过多年以后,得失的过程如此冷漠 ============================
Fishman
尊榮會員


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

發送簡訊給我
#4 引用回覆 回覆 發表時間:2005-08-09 10:59:15 IP:210.65.xxx.xxx 未訂閱
Hi t0288542,    請參考:    http://delphi.ktop.com.tw/topic.php?topic_id=30530 更改其 LockType 屬性為 ltBatchOptimistic 即可批次更新,而不會當離開該理資料即更新資料庫 PS:Sorry deity 大大,撞到你了! 發表人 -
------
Fishman
t0288542
中階會員


發表:216
回覆:254
積分:94
註冊:2004-10-06

發送簡訊給我
#5 引用回覆 回覆 發表時間:2005-08-09 11:34:57 IP:61.221.xxx.xxx 未訂閱
謝謝大家。 所提供相關資料。 簡略說明,是否應該這樣去設定。 ADOQuery -> locktype -> ltbatchoptimistic ADOQuery -> cursortype -> ctkeyset 新增:ADOQuery1.Insert 存檔:(1)利用SQL文作存檔。如此是否也會存入資料庫 (2)ADOQuery1.UpdateBatch 因為ADOQuery如連接兩表格時會影響另一表格,所以在異動資料時, 我都是利用語法來作動作。 麻煩大家。這樣對嗎。
cashxin2002
版主


發表:231
回覆:2555
積分:1937
註冊:2003-03-28

發送簡訊給我
#6 引用回覆 回覆 發表時間:2005-08-09 12:24:17 IP:202.62.xxx.xxx 未訂閱
您好﹗    沒錯﹒ 補充兩點﹕ 一﹒放棄儲存的語法為﹕ADOQuery1.CancelBatch; 二﹒將資料集元件的CursorType屬性值設為ctstatic亦可    ================================= 有空來瞅瞅我﹗因為我是您的朋友﹐有您真好﹗ ================================
------
忻晟
t0288542
中階會員


發表:216
回覆:254
積分:94
註冊:2004-10-06

發送簡訊給我
#7 引用回覆 回覆 發表時間:2005-08-09 13:57:51 IP:61.221.xxx.xxx 未訂閱
謝謝。 因為我目前的動作是輸入一筆按存檔。 如 ADOQuery2.Close; ADOQuery2.SQL.Clear; ADOQuery2.SQL.Add(' Insert Into COAMC '); ADOQuery2.SQL.Add(' (MC001,MC002,MC003,MC004,MC005,MC006,MC007,MC008, '); ADOQuery2.SQL.Add('  MC009,MC010,MC011,MC012,MC013,MC014,MC015,MC019) ');         ADOQuery2.SQL.Add(' Values ');         ADOQuery2.SQL.Add(' ('''+Trim(DBEdit1.Text)+''','''+Trim(DBEdit2.Text)+''','''+Trim(DBEdit3.Text)+''', ');         ADOQuery2.SQL.Add('  '''+Trim(DBEdit4.Text)+''','''+Trim(DBEdit5.Text)+''','''+Trim(DBEdit6.Text)+''','''+Trim(DBEdit7.Text)+''', ');         ADOQuery2.SQL.Add('  '''+Trim(DBEdit8.Text)+''','''+Trim(DBEdit9.Text)+''','''+Trim(DBEdit10.Text)+''','''+Trim(DBEdit11.Text)+''', ');         ADOQuery2.SQL.Add('  '''+Trim(DBEdit12.Text)+''','''+Trim(DBEdit13.Text)+''','''+Trim(DBEdit14.Text)+''','''+Trim(DBEdit15.Text)+''','''+Trim(DBEdit16.Text)+''') '); ADOQuery2.ExecSQL; //ADOQuery1.Post;這是我之前的方法,可是會異動另一個表格 ADOQuery1.UpdateBatch 以上的寫法。好像有點奇怪。 謝謝。
deity
尊榮會員


發表:90
回覆:876
積分:678
註冊:2003-05-09

發送簡訊給我
#8 引用回覆 回覆 發表時間:2005-08-09 14:58:36 IP:218.15.xxx.xxx 未訂閱
t0288542您好: 1、还得注意一个问题就是使用BathUpdate模式,执行的SQL命令必须是Select。 所以您上面直接下insert into,会将異動资料直接写入数据源。 改成如下方式:
procedure TForm1.FormCreate(Sender: TObject);
begin
  ADOQuery2.Close; 
  ADOQuery2.SQL.Clear;
  ADOQuery2.SQL.Add('Select * from COAMC');
  ADOQuery2.Open;
end;
procedure TForm1.Button1Click(Sender: TObject);
begin
  ADOQuery2.insert;
  ADOQuery2.FieldByName('MC001').AsString:=DBEdit1.Text;
  ADOQuery2.FieldByName('MC002').AsString:=DBEdit2.Text;
  ADOQuery2.FieldByName('MC003').AsString:=DBEdit3.Text;
  ……
  ADOQuery2.FieldByName('MC019').AsString:=DBEdit19.Text;
  ADOQuery2.Post;
end;    procedure TForm1.Button2Click(Sender: TObject);
begin
  ADOQuery2.UpdateBatch(arAll); //更新数据源
 //ADOQuery1.CancelBatch(arAll);//取消更新  
end;
 
2、更新和新增分开在不同的事件中。另此处的ADOQuery1应为ADOQuery2吧。而下ADOQuery1.post作用是为何?用insert into 的话,直接下ADOQuery2.ExecSQL;就可以了,无须再加ADOQuery2.Post; //ADOQuery1.Post;這是我之前的方法,可是會異動另一個表格 ADOQuery1.UpdateBatch 3、PS:Fishman前辈,您过谦了,您是数据库方面的专家,KTOP之领头羊。小弟有回答错误的地方还请前辈不吝指教,小弟本不该班门弄斧的 <> ============================ 为什么经过多年以后,得失的过程如此冷漠 ============================
t0288542
中階會員


發表:216
回覆:254
積分:94
註冊:2004-10-06

發送簡訊給我
#9 引用回覆 回覆 發表時間:2005-08-09 20:26:47 IP:59.104.xxx.xxx 未訂閱
謝謝 deity 我會試試您所提供方式, 為什麼會有ADOQuery1.post,原因是 ADOQuery1內原本就是要編輯資料. 但是此資料來源包含(COAMB/COAMC), 所以,每次做ADOQuery1.Delete都會將COAMB所對應某筆資料給刪除. 或者在ADOQuery1.POST也會發生同時要寫入COAMB指定的欄位的錯誤訊息. 所以,我只好在開一個ADOQuery2來作資料的異動. 請問這樣的方式.會不會不好. 麻煩您,謝謝.
t0288542
中階會員


發表:216
回覆:254
積分:94
註冊:2004-10-06

發送簡訊給我
#10 引用回覆 回覆 發表時間:2005-08-11 14:53:17 IP:61.221.xxx.xxx 未訂閱
謝謝大家. 可是如果輸入多筆時,選擇取消卻會發生錯誤訊息。 錯誤訊息如下。 資料列控制代碼參照到已刪除或標記為即將刪除的資料列。 請問,那裡有問題呢。 謝謝。
系統時間:2024-06-01 18:09:23
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!