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

ADOQuery的問題

答題得分者是:tech_state
TIY~2
一般會員


發表:26
回覆:37
積分:22
註冊:2003-08-07

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-08-11 23:14:17 IP:218.162.xxx.xxx 未訂閱
請問如果由遠端SOCKET傳送過來的字串 連續三次字串傳送過來(非常快) 分別是相關於SQL的語法 假設第一筆字串:"insert  To  某一筆資料"       二      :"Update  set 某一筆資料"       三      :"Update  set 某一筆資料"    接收端接收到了馬上做 socketready try{    ADOQuery->Close();    ADOQuery->SQL->Clear();    ADOQuery->Parameters->Clear();    ADOQuery->SQL->Add(接收到字串);    ADOQuery->ExecSQL();  }catch(...){ } 主要問題來了,因為接收太快,第二比字串進來時,第一筆字串還在處理,結果我的程式就出錯了,雖然錯誤省略掉了.但變成使二筆字串要做的更新資料庫的動作沒完成..請問大大有沒有完整的執行方式可以使3筆資料都順利完成.或則別的方式...請教我~
gemi0305
版主


發表:81
回覆:564
積分:629
註冊:2003-05-11

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-08-11 23:25:44 IP:61.224.xxx.xxx 未訂閱
TIY~2你好~    如果是資料庫的問題,小弟是無法幫你,因為我是肉腳, 但我覺得你這似乎是socket的問題... 你可以先參考以下文章, 再來想想,是否要對傳送的過程做個小手腳, 就可以不用更改原本對的SQL語法,    http://delphi.ktop.com.tw/topic.php?topic_id=35262    你可以在「發送端」加個Sleep(5)或是用Timer(很小的時間就可) 來使把這三筆資料不要被包在一個封包裡,不需像上篇在「接收瑞」那麼麻煩, 參考看看 不行的話,就要請資料庫女王上場了... 國泰平安
tech_state
版主


發表:44
回覆:638
積分:641
註冊:2003-02-10

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-08-12 00:11:13 IP:61.218.xxx.xxx 未訂閱
TIY~2, 您好 我也不認為是資料庫的問題。 gemi0305前輩提議在發送端動手腳。 我則是想到在接收端接收後, 先用一個變數或文字檔紀錄, 然後再逐一執行資料庫的部分, 不需要接收端一接收到資料就要馬上執行, 以免前一個動作未執行完成, 造成您目前碰到的問題。    以上想法,供您參考。    ================================= 涵養怒中氣。謹防順口言。留心忙裡錯。珍惜有時錢。 是非終日有,不聽自然無 天下本無事,庸人自擾之
系統時間:2024-04-26 8:24:23
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!