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

select也會有 List index out of bounds問題嗎

答題得分者是:careychen
17kobe
初階會員


發表:86
回覆:73
積分:31
註冊:2007-07-30

發送簡訊給我
#1 引用回覆 回覆 發表時間:2008-08-12 22:23:09 IP:220.132.xxx.xxx 訂閱
[code delphi]
//執行SQL命令,成功=true ,失敗=false
function SQLOpenOK(ADO:TADOQuery; sSQL:string): boolean;
function QuotedMsg(sMsg:string): string;
begin
sMsg:=Trim(sMsg);
if sMsg='' then Result:=''
else Result:=' [' sMsg ']';
end;
begin
Result:=False;
try
ADO.Close;
ADO.SQL.Clear;
ADO.SQL.Add(sSQL);
ADO.Open;
except
On E:EOleException Do
begin
ShowMessage(E.Message);
if E.ErrorCode=E_FAIL then //連線失敗
begin
ShowMessage('與DB連線失敗');
//Application.Terminate;
end;
exit;
end;
on E:Exception do
exit;
end;
Result:=True;
end;

//下列此行寫在thread當中,所以可能很多同時呼叫造成這樣的錯誤 ; 於此行發生錯誤
if not SQLOpenOK(TADOQuery1,'select top 1 淨值,日期 from ' m_FundName ' where 日期>=#' s_calc_date '# order by 日期;') then
ShowMessage('Query ERROR!!');
[/code]
出現List index out of bounds (118).問題 type EListError
用Select也會有這樣的問題,覺得非常其怪,請問我該如何解決這個錯誤,試了好久,試不出來,還是"隨機"不時出現。
careychen
尊榮會員


發表:41
回覆:580
積分:959
註冊:2004-03-03

發送簡訊給我
#2 引用回覆 回覆 發表時間:2008-08-12 22:30:19 IP:59.126.xxx.xxx 訂閱
  1. //下列此行寫在thread當中,所以可能很多同時呼叫造成這樣的錯誤 ; 於此行發生錯誤
  2. if not SQLOpenOK(TADOQuery1,'select top 1 淨值,日期 from ' m_FundName ' where 日期>=#' s_calc_date '# order by 日期;') then
  3. ShowMessage('Query ERROR!!');

你自己的問題,你自己回答了,請看之前有一篇是 Lu 大所講的內容 ( 因為我自己也犯了這個錯 )http://delphi.ktop.com.tw/board.php?cid=168&fid=920&tid=94679

因為在 Thread 的關係,所以你的 ADO 元件,常常會被別的 Thread 改掉了 SQL 的內容,而造成錯誤
請獨立每個 Thread 中有自已的 ADO 元件,而且使用自己的 ConnectionString 來避免
------
價值的展現,來自於你用哪一個角度來看待它!!
系統時間:2024-04-25 17:06:26
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!