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

SQL Statement 問題

尚未結案
joe_ung
一般會員


發表:12
回覆:21
積分:6
註冊:2003-10-16

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-10-20 12:25:28 IP:202.175.xxx.xxx 未訂閱
temp1:=StrtoInt(eotT.Text); temp2:=StrtoInt(ppT.Text); temp3:=StrtoInt(remainT.Text); ADOQuery1.SQL.Add('insert into tiov PPNO,TRIP_CODE,DOSIGN,DOSTART,EOT,PRE_PAYMENT,REMAINPAPER_NO)'); ADOQuery1.sql.add('values (''' passportT.Text ''',''' tcT.Text ''',''' dateT.Text ''',''' dostartT.Text ''',''' eotT.Text ''',''' ppT.Text ''',''' remainT.Text ''',''' nopaperT.Text ''')'); ADOQuery1.ExecSQL; 小弟想把temp1,temp2&temp3放進sql statement內,應怎樣呢? 請各位前輩指教
hagar
版主


發表:143
回覆:4056
積分:4445
註冊:2002-04-14

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-10-20 13:12:40 IP:202.39.xxx.xxx 未訂閱
temp1/temp2/temp3 要放進 SQL 的哪裏? 另外, 您 Insert 的 SQL 少了一個左括號    --- 歡迎光臨 KTop 研究院
guohua_fu
一般會員


發表:44
回覆:50
積分:18
註冊:2003-06-19

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-10-20 14:40:51 IP:211.96.xxx.xxx 未訂閱
閣下的意思是說將Temp1/Temp2/Temp3放到sql statement內行不行?還是說應該怎麼放呢?問題沒說清楚噢!
------
jacky
joe_ung
一般會員


發表:12
回覆:21
積分:6
註冊:2003-10-16

發送簡訊給我
#4 引用回覆 回覆 發表時間:2003-10-20 15:07:58 IP:202.175.xxx.xxx 未訂閱
多謝提點呀!! 本人是利用textfield來填寫資料的,但要求的數據型態是數字,所以要用一個變數來改變資料型態. temp1,temp2&temp3就是改變了之後的資料型態(int) 它們分別是用來取代sql句子中的eotT.text,ppT.text和remainT.text的 這樣各位前輩明白嗎? 多謝指教杯呀!!
cashxin2002
版主


發表:231
回覆:2555
積分:1937
註冊:2003-03-28

發送簡訊給我
#5 引用回覆 回覆 發表時間:2003-10-20 16:27:30 IP:63.84.xxx.xxx 未訂閱
您好﹗    試試如下使用ADOQuery1.Parameters的方法﹕
begin
  ADOQuery1.Close;
  ADOQuery1.SQL.Clear;  
  ADOQuery1.SQL.Add('insert into tiov (PPNO,TRIP_CODE,DOSIGN, ');
  ADOQuery1.SQL.Add('DOSTART, EOT,PRE_PAYMENT,REMAINPAPER_NO ');
  ADOQuery1.SQL.Add(') values (');
  ADOQuery1.SQL.Add('''' passportT.Text ''', ''' tcT.Text ''', ');
  ADOQuery1.SQL.Add('''' dateT.Text ''', ''' dostartT.Text ''', ');
  ADOQuery1.SQL.Add(':Temp1, :Temp2, :Temp3, ''' nopaperT.Text '''');
  ADOQuery1.Parameters.ParamByName('Temp1').Value := StrToInt(eotT.Text);
  ADOQuery1.Parameters.ParamByName('Temp1').Value := StrToInt(ppT.Text);
  ADOQuery1.Parameters.ParamByName('Temp1').Value := StrToInt(remainT.Text);
  ADOQuery1.ExecSQL;
end;
===================== 努力,相信會獲得美麗! 忻晟
------
忻晟
joe_ung
一般會員


發表:12
回覆:21
積分:6
註冊:2003-10-16

發送簡訊給我
#6 引用回覆 回覆 發表時間:2003-10-20 17:33:42 IP:202.175.xxx.xxx 未訂閱
哦....明白了!! 另外,如果用ADOCommand會有何不同呢?
cashxin2002
版主


發表:231
回覆:2555
積分:1937
註冊:2003-03-28

發送簡訊給我
#7 引用回覆 回覆 發表時間:2003-10-20 18:09:22 IP:63.84.xxx.xxx 未訂閱
您好﹗    ADOCommand元件是同樣的使用方法﹒只是說ADOCommand元件配合做沒有回傳資料的SQL語法(如﹕Insert, Delete, Update)等﹒而ADOQuery則都可以﹒    參考看看﹗    ===================== 努力,相信會獲得美麗! 忻晟
------
忻晟
系統時間:2024-05-19 15:25:02
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!