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

在 delphi 2009 中 DBExpress 為何在使用BeginTransaction後就不能SELECT資料了,是Delphi 的BUG嗎

缺席
chihping
一般會員


發表:3
回覆:6
積分:1
註冊:2009-06-18

發送簡訊給我
#1 引用回覆 回覆 發表時間:2009-06-18 12:11:38 IP:114.45.xxx.xxx 訂閱
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

發送簡訊給我
#2 引用回覆 回覆 發表時間:2009-06-18 13:27:43 IP:122.116.xxx.xxx 訂閱
dsQry.ExecSQL

因為你的 sql 是 select 所以改成 dsQry.Open; 試看看
chihping
一般會員


發表:3
回覆:6
積分:1
註冊:2009-06-18

發送簡訊給我
#3 引用回覆 回覆 發表時間:2009-06-18 13:37:15 IP:114.45.xxx.xxx 訂閱
試過了,就算用 TSQLQuery 來SELECT 只要有BeginTransaction 就不行

===================引 用 tuga 文 章===================
dsQry.ExecSQL

因為你的 sql 是 select 所以改成 dsQry.Open; 試看看
GrandRURU
站務副站長


發表:240
回覆:1680
積分:1874
註冊:2005-06-21

發送簡訊給我
#4 引用回覆 回覆 發表時間:2009-06-19 08:41:39 IP:203.75.xxx.xxx 未訂閱
1.請善用ktop的程式碼區塊功能
2.DBX的「RecordCount 」功能限制較多,建議你可用SQL中的「COUNT(*)」或是將結果導到ClientDataSet中再使用「RecordCount」函式來取代。

以上
tuga
高階會員


發表:16
回覆:109
積分:120
註冊:2002-07-13

發送簡訊給我
#5 引用回覆 回覆 發表時間:2009-06-19 10:21:54 IP:122.116.xxx.xxx 訂閱
你的 dsQry  是 TSQLUQERY 嗎?

如果是的話 TSQLUQERY 是一個 順向的 query , 用 record count 會有問

改用 SimpleDataSet 試看看 或是用 上面大哥 講的, 用 client data set

或是直接用 select count(*) from mytest
chihping
一般會員


發表:3
回覆:6
積分:1
註冊:2009-06-18

發送簡訊給我
#6 引用回覆 回覆 發表時間:2009-06-19 11:24:56 IP:114.45.xxx.xxx 訂閱
問題不在 RecordCount 或 COUNT(*),因為就算我直接去抓欄位資料也不行,ClientDataSet 與 SimpleDataSet我也都試過了只要有使用BeginTransaction 就會錯誤.


===================引 用 GrandRURU 文 章===================
1.請善用ktop的程式碼區塊功能
2.DBX的「RecordCount 」功能限制較多,建議你可用SQL中的「COUNT(*)」或是將結果導到ClientDataSet中再使用「RecordCount」函式來取代。

以上
系統時間:2024-04-27 12:10:42
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!