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

請問單行sql語法過長時

缺席
bogey
一般會員


發表:4
回覆:8
積分:2
註冊:2006-12-19

發送簡訊給我
#1 引用回覆 回覆 發表時間:2007-04-14 15:47:36 IP:220.130.xxx.xxx 訂閱
請問我在程式裡將變數帶入sql,如下:

FOR i:=0 to 200 do
begin
v_TxRefNo:=inttostr(i) ' or TxRefNo='
end;

Close;
SQL.Clear;
SQL.Add('Select * from Mas where TxRefNo=' v_TxRefNo '');
SQL.SaveToFile('aa.txt');
SQL.Open;

請問aa.txt的資料內容是對的,
但在delphi run時,sql open會出現 "Some internal limit (see context)"
的錯誤訊息,
還請各位高手不吝指教..

ps.我要對Mas這table做insert的整批處理,無法 每筆做ApplyUpdates的動作
pedro
尊榮會員


發表:152
回覆:1187
積分:892
註冊:2002-06-12

發送簡訊給我
#2 引用回覆 回覆 發表時間:2007-04-14 16:16:11 IP:60.248.xxx.xxx 未訂閱
試著用SQL Analyer去Try您這個完整的Sql 語法t吧!
看是不是有問題?

另外一個做法可以用Transaction把多筆Insert綁在同一個交易
BEGIN TRANSACTION, COMMIT TRANSACTION, COMMIT WORK, ROLLBACK TRANSACTION, ROLLBACK
bogey
一般會員


發表:4
回覆:8
積分:2
註冊:2006-12-19

發送簡訊給我
#3 引用回覆 回覆 發表時間:2007-04-14 16:27:11 IP:220.130.xxx.xxx 訂閱
感謝pedro756901大大的回答,sql的語法沒問題,Transaction遇到query.close會有很奇怪的問題,
所以我是最後才處理applyupdates,如果只針對單行sql這問題,有什麼好的處理辦法嗎?
bogey
一般會員


發表:4
回覆:8
積分:2
註冊:2006-12-19

發送簡訊給我
#4 引用回覆 回覆 發表時間:2007-04-14 17:54:16 IP:220.130.xxx.xxx 訂閱
@@ 原來是sql一行不能超過1024個字元..感謝了..
bogey
一般會員


發表:4
回覆:8
積分:2
註冊:2006-12-19

發送簡訊給我
#5 引用回覆 回覆 發表時間:2007-04-14 19:51:01 IP:220.130.xxx.xxx 訂閱
..不對..看來是當query的RequestLive設成true時..sql的字元不能超過4千多..
老大..救救小弟啊..
fadichen
初階會員


發表:29
回覆:68
積分:29
註冊:2003-09-11

發送簡訊給我
#6 引用回覆 回覆 發表時間:2007-04-14 23:35:55 IP:61.230.xxx.xxx 訂閱
4k bytes ,  用 blob 的方式寫入就可以吧!

TBlobField(EmInfoQuery.FieldByName('aaa')).LoadFromFile('a.txt');

你試一下

系統時間:2024-05-19 12:43:30
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!