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

SQL老是出現逾時??

尚未結案
gavinj123
初階會員


發表:88
回覆:48
積分:27
註冊:2002-10-15

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-03-02 15:41:45 IP:211.75.xxx.xxx 未訂閱
我有一個約5萬筆的資料要寫入SQL中,我用ADO以程式讓它一筆筆的寫入,因為速度很慢,所以我都是半夜放著讓它RUN,可是早上一去到都是出現逾時,有人知道是為什麼嗎? 或是要如何避免??
l630521
資深會員


發表:15
回覆:349
積分:372
註冊:2003-02-17

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-03-02 16:07:58 IP:210.66.xxx.xxx 未訂閱
我之前用ADOStoredProc有遇過,我是把CommandTimeout設成0就解決了,原因我也不曉得,你試試看! Ian
terrychen
尊榮會員


發表:90
回覆:794
積分:501
註冊:2003-05-01

發送簡訊給我
#3 引用回覆 回覆 發表時間:2004-03-02 16:17:47 IP:61.221.xxx.xxx 未訂閱
您好: 參考http://delphi.ktop.com.tw/topic.php?TOPIC_ID=45388 ~~應無所住而生其心~~
P.D.
版主


發表:603
回覆:4038
積分:3874
註冊:2006-10-31

發送簡訊給我
#4 引用回覆 回覆 發表時間:2004-03-03 02:30:26 IP:61.71.xxx.xxx 未訂閱
引言: 我有一個約5萬筆的資料要寫入SQL中,我用ADO以程式讓它一筆筆的寫入,因為速度很慢,所以我都是半夜放著讓它RUN,可是早上一去到都是出現逾時,有人知道是為什麼嗎? 或是要如何避免??
如果你是用 do while 方式來做, 由於buffer問題, 的確會造成速度越來越慢, 最後很可能會導致timeout現象, 幾個做法嘗試看看 1.用程式設定每n筆寫入後關閉SQL, 再重新CONNECT資料庫 2.不知道你的寫法為何 儘量不要用 SELECT ... , APPEND, POST方式, 因為只是要寫回可以用 UPDATE, INSER INTO方式會比較快 3.改用STOREPROCEURE 方式解決 4.如果一定要用 WHILE 方式來執行的話, 不妨在 WHILE中加入 APPLICATION.PROCESSMESSAGE, 讓WINDOWS不會因為在 WHILE中陷入死迴圈的狀況, 而讓window誤認為沒有回應而timeout 以上純屬個人意見~~~
系統時間:2024-11-23 9:56:30
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!