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

站長請教各位一個TQuery.Close的觀念問題

 
領航天使
站長


發表:12216
回覆:4186
積分:4084
註冊:2001-07-25

發送簡訊給我
#1 引用回覆 回覆 發表時間:2002-07-10 12:31:21 IP:192.168.xxx.xxx 未訂閱
站長被一個網友問到一個觀念的問題: 拉一個TQuery元件(Query1)於TForm上(Form1), 當此Form1.Close且Form1.Free之後 原先Query1已open的資料庫通道,需不需要由程式去下Query1.Close? 1.是Form1 Close時就會自動執行Query1.Close 2.或是Form1 Free時會自動執行Query1.Close 3.或是一定要在Form1.OnClose()事件中自己去下Query1.Close的動作,才能讓資料庫的通道去除! 網友您的答案是多少? 謝謝指導! ~~~Delphi K.Top討論區站長~~~
------
~~~Delphi K.Top討論區站長~~~
ryback
一般會員


發表:0
回覆:4
積分:0
註冊:2002-06-25

發送簡訊給我
#2 引用回覆 回覆 發表時間:2002-07-10 14:02:26 IP:203.69.xxx.xxx 未訂閱
若是用拉元件的方式建立這一個Query 在Form被free掉時會一並被free掉 若是在程式碼中自行create 就必須在程式中自行free 也就是說我會選 (2)
owenyang
一般會員


發表:21
回覆:17
積分:7
註冊:2002-03-26

發送簡訊給我
#3 引用回覆 回覆 發表時間:2002-07-10 14:52:35 IP:139.223.xxx.xxx 未訂閱
我也是選 (2)
danny
版主


發表:100
回覆:522
積分:595
註冊:2002-03-11

發送簡訊給我
#4 引用回覆 回覆 發表時間:2002-07-10 15:36:31 IP:210.200.xxx.xxx 未訂閱
引言: 站長被一個網友問到一個觀念的問題: 拉一個TQuery元件(Query1)於TForm上(Form1), 當此Form1.Close且Form1.Free之後 原先Query1已open的資料庫通道,需不需要由程式去下Query1.Close? 1.是Form1 Close時就會自動執行Query1.Close 2.或是Form1 Free時會自動執行Query1.Close 3.或是一定要在Form1.OnClose()事件中自己去下Query1.Close的動作,才能讓資料庫的通道去除! 網友您的答案是多少? 謝謝指導! ~~~Delphi K.Top討論區站長~~~
我查 TQuery 的 Source code 如下:
destructor TQuery.Destroy;
begin
  Destroying;
  Disconnect;
  SQL.Free;
  FParams.Free;
  FDataLink.Free;
  StrDispose(SQLBinary);
  inherited Destroy;
end;    procedure TQuery.Disconnect;
begin
  Close;
  UnPrepare;
end;
TQuery 的 owner 是 form, 而 onwer 有責任 Free 所屬的 object, 所以在 Destroy 中是會作 Close 的動作.
------
將問題盡快結案也是一種禮貌!
領航天使
站長


發表:12216
回覆:4186
積分:4084
註冊:2001-07-25

發送簡訊給我
#5 引用回覆 回覆 發表時間:2002-07-10 17:09:58 IP:192.168.xxx.xxx 未訂閱
感謝ryback,owenyang,danny等網友的回覆, 讓我的觀念更加踏實,謝謝! ~~~Delphi K.Top討論區站長~~~
------
~~~Delphi K.Top討論區站長~~~
系統時間:2024-11-25 14:59:51
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!