在 delphi 2009 中 DBExpress 為何在使用BeginTransaction後就不能SELECT資料了,是Delphi 的BUG嗎 |
缺席
|
chihping
一般會員 發表:3 回覆:6 積分:1 註冊:2009-06-18 發送簡訊給我 |
procedure TForm1.Button1Click(Sender: TObject);
var sSQL : String; Transaction: TDBXTransaction; begin Transaction := SQLConnection1.BeginTransaction(TDBXIsolations.ReadCommitted); try try sSQL := 'SELECT id FROM MyTest'; dsQry.Close; dsQry.CommandText := sSQL; dsQry.ExecSQL; if (dsQry.RecordCount > 0) then //只要使用 BeginTransaction 此行就會錯誤 (Commands out of Sync;) begin exit; end; SQLConnection1.CommitFreeAndNil(Transaction); except SQLConnection1.RollbackFreeAndNil(Transaction); end; finally SQLConnection1.RollbackIncompleteFreeAndNil(Transaction); end; end; |
tuga
高階會員 發表:16 回覆:109 積分:120 註冊:2002-07-13 發送簡訊給我 |
|
chihping
一般會員 發表:3 回覆:6 積分:1 註冊:2009-06-18 發送簡訊給我 |
|
GrandRURU
站務副站長 發表:240 回覆:1680 積分:1874 註冊:2005-06-21 發送簡訊給我 |
|
tuga
高階會員 發表:16 回覆:109 積分:120 註冊:2002-07-13 發送簡訊給我 |
|
chihping
一般會員 發表:3 回覆:6 積分:1 註冊:2009-06-18 發送簡訊給我 |
問題不在 RecordCount 或 COUNT(*),因為就算我直接去抓欄位資料也不行,ClientDataSet 與 SimpleDataSet我也都試過了只要有使用BeginTransaction 就會錯誤.
===================引 用 GrandRURU 文 章=================== 1.請善用ktop的程式碼區塊功能 2.DBX的「RecordCount 」功能限制較多,建議你可用SQL中的「COUNT(*)」或是將結果導到ClientDataSet中再使用「RecordCount」函式來取代。 以上 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |