如何改進原來程式ADOTable查找部分? |
尚未結案
|
mathewzhao
中階會員 ![]() ![]() ![]() 發表:121 回覆:164 積分:67 註冊:2003-04-04 發送簡訊給我 |
Q1‧請問如何改寫?
原先用adotable寫一程式,查找是否存在該Record,如果存在,則從該Record取出一個指定field,如下:
try
if adotable1‧locate('stdNO',edit1‧text,[]) then
begin
EDIT2‧text:=adotable1‧Fields[3]‧asstring;
end;
except
showmessage('!!!');
end;
因資料庫越來越大,希望用adoquery改寫這部分以提高速度,請問如何改寫或者有無更好的方法。 Q2‧請問如何在網路故障時將"[DBNetlib]‧‧‧"提示不要顯示,並儘快執行except部分
原本想在網路故障時,出現except部分,但實際是過一倆分鐘後,在出現"[DBNetlib][connectionOpen[connect()‧]SQL server 不存在或Access 被拒絕‧"提示後,except才執行。請問如何將"[DBNetlib]‧‧‧"提示不要顯示,並儘快執行except部分
|
T.J.B
版主 ![]() ![]() ![]() ![]() ![]() 發表:29 回覆:532 積分:497 註冊:2002-08-14 發送簡訊給我 |
可以直接下sql,不要用locate 這樣會快很多
如 ; try
query1.sql.add('select * from xxx ');
query1.sql.add(' where stdNO = :stdNO ');
query1.ParamByName('stdNO').asstring:= edit1.text;
query1.open;
if not query1.isempty then
//指定field
except
raise exception.create('資料庫無法操作,請詢問DBA');
end; 因為你的except裡面是用showmessage 所以無法阻止資料庫的錯誤訊息出來
你必須要自定錯誤訊息(去create一個錯誤訊息)這樣才會把資料庫的錯誤訊
息擋掉 天行健
君子當自強不息~~@.@ 發表人 - T.J.B 於 2003/04/23 13:34:07
------
天行健 君子當自強不息~~@.@ |
timhuang
尊榮會員 ![]() ![]() ![]() ![]() ![]() ![]() 發表:78 回覆:1815 積分:1608 註冊:2002-07-15 發送簡訊給我 |
引言: Q1‧請問如何改寫? 因資料庫越來越大,希望用adoquery改寫這部分以提高速度,請問如何改寫或者有無更好的方法。資料庫愈大, 用 adotable 本來就會愈慢, 要加快的方法, 用 adoquery 來做是正確的, 先將資料縮小範圍後再利用 locate function 來指定, 你的程式修改如下: try adoquery1.close; adoquery1.SQL.Add('select * from tablea where stdNO like ''' Edit1.Text '%'' '); adoquery1.open; if adoquery1.locate('stdNO', edit1.text, []) then begin EDIT2.text :=adoquery1.Fields[3].asstring; end; except showmessage('!!!'); end;Q2 的部分, 請問你是怎麼連上資料庫的? 用 adoconnection -> adotable 嗎? 還是直接用 adotable 呢, 是否有使用 odbc 呢? |
mathewzhao
中階會員 ![]() ![]() ![]() 發表:121 回覆:164 積分:67 註冊:2003-04-04 發送簡訊給我 |
|
chih
版主 ![]() ![]() ![]() ![]() ![]() ![]() 發表:48 回覆:1186 積分:639 註冊:2002-04-02 發送簡訊給我 |
|
mathewzhao
中階會員 ![]() ![]() ![]() 發表:121 回覆:164 積分:67 註冊:2003-04-04 發送簡訊給我 |
各位先進好,我原先的程式使用一個ADOQuery和一個ADOTable,因資料庫越來越大,希望用一個adoquery改部分以提高速度。我根據T‧J‧B的建議稍做改變,將Query改為ADOQuery,但不知為何一直出現except提示(ADOQuery的connectionstring、Active都沒問題),請各位先進指點,謝謝! adoquery1‧close;
adoquery1‧sql‧clear;
try
adoquery1‧sql‧add('select * from Library ');
adoquery1‧sql‧add(' where StdNO = :StdNO ');
adoquery1‧Parameters‧ParamByName('StdNO')‧value: =edit1text;
adoquery1‧open;
if not adoquery1‧isempty then
begin
EDIT2‧text:=adoquery1‧Fields[3]‧asstring;
end
else
showmessage('學號不存在!');
except
raise exception‧create('資料庫無法操作,請詢問DBA');
end;
|
timhuang
尊榮會員 ![]() ![]() ![]() ![]() ![]() ![]() 發表:78 回覆:1815 積分:1608 註冊:2002-07-15 發送簡訊給我 |
本站聲明 |
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。 2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。 3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇! |