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

錯誤訊息

答題得分者是:cmj
lilisn
一般會員


發表:35
回覆:62
積分:24
註冊:2003-03-09

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-04-02 17:56:29 IP:61.228.xxx.xxx 未訂閱
練習寫 dbf (c型態) 資料轉入 mysql2000 dbo (valchar) 結果不成功,出限error message /// The name sa is not permitted is the context only constants expressions or variables allowed here column name are not permitted. /// procedure TForm1.Button1Click(Sender: TObject); var sa,sb,sc:string; begin TABLE1.First; while (not table1.Eof) do begin Sc:=TABLE1NO.AsString; Sa:=TABLE1NAME.AsString; Sb:=TABLE1NAME1.AsString; ADOQUERY1.SQL.Clear; ADOQUERY1.SQL.text:='INSERT INTO DISTRICT (districtcode,districtname,districtnumber) values (sa,sb,sc)'; adoquery1.ExecSQL; table1.Next; end; end;
channel
尊榮會員


發表:67
回覆:707
積分:854
註冊:2002-05-02

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-04-02 18:04:29 IP:211.21.xxx.xxx 未訂閱
引言: 練習寫 dbf (c型態) 資料轉入 mysql2000 dbo (valchar) 結果不成功,出限error message /// The name sa is not permitted is the context only constants expressions or variables allowed here column name are not permitted. /// procedure TForm1.Button1Click(Sender: TObject); var sa,sb,sc:string; begin TABLE1.First; while (not table1.Eof) do begin Sc:=#39 TABLE1NO.AsString #39; Sa:=#39 TABLE1NAME.AsString #39; Sb:=#39 TABLE1NAME1.AsString #39; ADOQUERY1.SQL.Clear; ADOQUERY1.SQL.text:='INSERT INTO DISTRICT (districtcode,districtname,districtnumber) values (sa,sb,sc)'; adoquery1.ExecSQL; table1.Next; end; end;
您修改紅色的地方試試看! ~小弟淺見,參考看看~
------
~小弟淺見,參考看看~
Justmade
版主


發表:94
回覆:1934
積分:2030
註冊:2003-03-12

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-04-02 18:48:54 IP:218.16.xxx.xxx 未訂閱
1. 在 SQL.Text 的資料是直接傳給 數據庫的,所以你的 Sa, Sb, Sc 字眼(而非內容)就直接傳給數據庫了,試問據庫了又甚知甚麼是 Sa 呢?所以你應將變數的內容並非名稱傳過去。    2. 還要知道的是欄位的形態,是字串呢還是數字等等,字串要用'來括住,數字可以不用。例如當你的 Name 及 Name1 是字串而 No 是數字,就應如以下寫:    
procedure TForm1.Button1Click(Sender: TObject);
var sa,sb,sc:string;
begin
  TABLE1.First;
  while (not table1.Eof) do
        begin
        Sc:=TABLE1NO.AsString;
        Sa:=TABLE1NAME.AsString;
        Sb:=TABLE1NAME1.AsString;
        ADOQUERY1.SQL.Clear;
        ADOQUERY1.SQL.text:='INSERT INTO DISTRICT (districtcode,districtname,districtnumber) values ('''   sa   ''','''   sb   ''','   sc)';
        adoquery1.ExecSQL;
        table1.Next;
        end;
end;
註 : 由於 ' 用作括號,若想要在字串裡有 ' 字就要以 ''(兩個'不是一個") 來代替,例如 ',' 即是 字串 , ''',''' 即是字串 ',' 因為第一個及最後一個 ' 是括住字串,又那兩對 '' 就各組成一毎字串裡的 ' 。 發表人 - Justmade 於 2003/04/02 18:59:01
cmj
高階會員


發表:15
回覆:242
積分:226
註冊:2002-06-12

發送簡訊給我
#4 引用回覆 回覆 發表時間:2003-04-02 18:59:16 IP:211.76.xxx.xxx 未訂閱
引言: 練習寫 dbf (c型態) 資料轉入 mysql2000 dbo (valchar) 結果不成功,出限error message /// The name sa is not permitted is the context only constants expressions or variables allowed here column name are not permitted. /// procedure TForm1.Button1Click(Sender: TObject); var sa,sb,sc:string; begin ADOQUERY1.SQL.Clear; ADOQUERY1.SQL.text:='INSERT INTO DISTRICT (districtcode,districtname,districtnumber) values (:sa,:sb,:sc)'; TABLE1.First; while (not table1.Eof) do begin Sc:=TABLE1NO.AsString; Sa:=TABLE1NAME.AsString; Sb:=TABLE1NAME1.AsString; adouery1.Parameters.ParamByName('sa').value:=sa; adouery1.Parameters.ParamByName('sb').value:=sb; adouery1.Parameters.ParamByName('sc').value:=sc; adoquery1.ExecSQL; table1.Next; end; end;
建議儘量用參數方式傳遞值,比較不易出錯,容易懂
chih
版主


發表:48
回覆:1186
積分:639
註冊:2002-04-02

發送簡訊給我
#5 引用回覆 回覆 發表時間:2003-04-02 19:00:02 IP:61.216.xxx.xxx 未訂閱
ADOQUERY1.SQL.text:='INSERT INTO DISTRICT (districtcode,districtname,districtnumber) values (' #39 sa #39 ',' #39 sb #39 ',' #39 sc #39 ')'; TRY TRY SEE
lilisn
一般會員


發表:35
回覆:62
積分:24
註冊:2003-03-09

發送簡訊給我
#6 引用回覆 回覆 發表時間:2003-04-02 23:38:51 IP:61.228.xxx.xxx 未訂閱
[quote] 1. 在 SQL.Text 的資料是直接傳給 數據庫的,所以你的 Sa, Sb, Sc 字眼(而非內容)就直接傳給數據庫了,試問據庫了又甚知甚麼是 Sa 呢?所以你應將變數的內容並非名稱傳過去。 謝謝Justmade提醒 2. 還要知道的是欄位的形態,是字串呢還是數字等等,字串要用'來括住,數字可以不用。例如當你的 Name 及 Name1 是字串而 No 是數字,就應如以下寫: >> no是字串 << [code] ADOQUERY1.SQL.text:='INSERT INTO DISTRICT (districtcode,districtname,districtnumber) values [red](''' sa ''',''' sb ''',''' sc ''' )' 出現 error message String or binary data would be truncated 上述多位大大指導,經過test 只有cmj寫法可行
系統時間:2024-05-04 12:01:52
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!