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

如何在 DLL 中調用 ADO, 並共用 ADOConnection?

尚未結案
FrederickPau
資深會員


發表:4
回覆:161
積分:268
註冊:2002-11-04

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-02-07 07:34:08 IP:61.228.xxx.xxx 未訂閱
我有一個程式會以 MultiThread 呼叫 DLL (同時多個 Thread 呼叫同一個 DLL), 而 DLL 的功能是透過 ADO 對資料庫做存取, 請問 DLL 要如何寫才會共用同一個 ADOConnection? 除了像 jackkcg 大大發表的 http://delphi.ktop.com.tw/topic.php?TOPIC_ID=22386 的方式, 由外部傳入 TADOConnection 的方式以外, 是否能由 DLL 本身著手呢? 謝謝大家
lukyshu
中階會員


發表:16
回覆:120
積分:93
註冊:2002-04-19

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-02-07 09:18:06 IP:210.85.xxx.xxx 未訂閱
引言: 我有一個程式會以 MultiThread 呼叫 DLL (同時多個 Thread 呼叫同一個 DLL), 而 DLL 的功能是透過 ADO 對資料庫做存取, 請問 DLL 要如何寫才會共用同一個 ADOConnection? 除了像 jackkcg 大大發表的 http://delphi.ktop.com.tw/topic.php?TOPIC_ID=22386 的方式, 由外部傳入 TADOConnection 的方式以外, 是否能由 DLL 本身著手呢? 謝謝大家
當然可以囉! 開個unit然後如此宣告: unit app_init; interface uses ADODB; var //******公用變數 *************************************** appConnection: TADOConnection; //資料庫連線 implementation initialization 在這裡動態建立ADOConnection就行啦! finalization end. 你試試看囉! 台灣 Delphi 俱樂部
PostgreSQL、FastReport專業討論區
http://www.delphi.club.tw


------
台灣 Delphi 俱樂部 

PostgreSQL、FastReport專業討論區

http://www.delphi.club.tw

FrederickPau
資深會員


發表:4
回覆:161
積分:268
註冊:2002-11-04

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-02-16 11:05:46 IP:61.228.xxx.xxx 未訂閱
嗯 ... 先謝謝你的解答 ... 但是這樣好像還是有問題 1. 這樣的情況一定會用到 OleCoInitialize 2. TADOConnection 在 Create 之後, 應該在什麼時候做 Free 呢? 3. 發現在 DLL 做完之後 Free 掉 TADOConnection 時, 其他正在 work 的Thread 會發生問題. 4. 所以這種情況下 ... 我又加了 Critical Section, 結果終於好了. 只是 ... 這是我自己試出來的 ... 不知道是不是還有更好更方便的方法?
系統時間:2024-06-16 19:46:46
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!