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

請問ADOQuery元件如在迴圈判斷中~命令如何去設定~

尚未結案
t0288542
中階會員


發表:216
回覆:254
積分:94
註冊:2004-10-06

發送簡訊給我
#1 引用回覆 回覆 發表時間:2004-12-09 16:01:41 IP:61.221.xxx.xxx 未訂閱
請問各位~    如果要讀取某個欄位多筆資料時,其索引值應該如何寫呢~ K:=ADOQuery1.RecordCount;  //計筆資料筆數 For I:=0 To K do begin   ADOQuery1.FieldByName('PC001').AsString; {請問它的索引值應該加入以上敍述的那裡} : : end; 謝謝~
writeman
初階會員


發表:31
回覆:34
積分:28
註冊:2004-02-17

發送簡訊給我
#2 引用回覆 回覆 發表時間:2004-12-09 16:10:58 IP:61.70.xxx.xxx 未訂閱
hi 試試這樣    
  while not adoquery1.Eof do begin
    no1:= trim(adoquery1.Fields.fieldS[0].AsString);
    no2:= trim(adoquery1.Fields.fieldS[1].AsString);
    adoquery1.Next;
  end;
發表人 - writeman 於 2004/12/09 16:16:17
t0288542
中階會員


發表:216
回覆:254
積分:94
註冊:2004-10-06

發送簡訊給我
#3 引用回覆 回覆 發表時間:2004-12-10 15:11:29 IP:61.221.xxx.xxx 未訂閱
謝謝~ 如果為數值形態的資料呢~ 謝謝~
timhuang
尊榮會員


發表:78
回覆:1815
積分:1608
註冊:2002-07-15

發送簡訊給我
#4 引用回覆 回覆 發表時間:2004-12-10 16:21:25 IP:203.95.xxx.xxx 未訂閱
Hi, 請使用 AsInteger 或 AsFloat 即可!
t0288542
中階會員


發表:216
回覆:254
積分:94
註冊:2004-10-06

發送簡訊給我
#5 引用回覆 回覆 發表時間:2004-12-15 13:16:10 IP:61.221.xxx.xxx 未訂閱
請問各位~    以下的描述是否有問題~    DPC003 := ADOQuery1.Fields.fieldS[2].AsInteger; //訂單包裝數量 SQL.Add('Insert Into COPTD '); SQL.Add('(TD001,TD002,TD003,TD004,TD005,TD006)'); SQL.Add(' Values (''A01'',''Admin'',''110'',DPC003,0,0)');    原本我在猜想是否是我的SQL文有問題~ 結果,我將DPC003用一個數值去取代~ 是可以執行~ 以下是我的錯誤訊息~ 謝謝~    
cashxin2002
版主


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

發送簡訊給我
#6 引用回覆 回覆 發表時間:2004-12-15 14:06:17 IP:202.62.xxx.xxx 未訂閱
您好﹗    因為您是使用Integer變數﹐所以無法直接將Integer變數寫入在SQL中﹐改為如下紅色處敘述試試﹕
begin
  ADOQuery1.Close;
  ADOQuery1.SQL.Clear;
  ADOQuery1.SQL.Add('Insert Into COPTD ');
  ADOQuery1.SQL.Add('(TD001,TD002,TD003,TD004,TD005,TD006)');
  ADOQuery1.SQL.Add(' Values (''A01'',''Admin'',''110'',:DPCTemp,0,0)');
  ADOQuery1.ParamByName('DPCTemp').AsInteger := DPC003;
  ADOQuery1.ExecSQL;
end;
========================= 我是您的朋友﹐有您真好﹗ =========================
------
忻晟
t0288542
中階會員


發表:216
回覆:254
積分:94
註冊:2004-10-06

發送簡訊給我
#7 引用回覆 回覆 發表時間:2004-12-15 15:02:58 IP:61.221.xxx.xxx 未訂閱
Hi cashxin2002 您好~    可是錯誤訊息出現在 ParamByName('DPCTemp').AsInteger := DPC003; 底下訊息框 [Error] cop1.pas(245): Undeclared identifier: 'ParamByName' 另外:DPCTemp~前面是否是要加冒號~DPCTemp這個變數需作宣告動作嗎 ADOQuery1.SQL.Add(' Values ''A01'',''Admin'',''110'',:DPCTemp,0,0)'); 麻煩您~^^
cashxin2002
版主


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

發送簡訊給我
#8 引用回覆 回覆 發表時間:2004-12-15 15:24:08 IP:202.62.xxx.xxx 未訂閱
您好﹗    改成這樣﹕ ADOQuery1.Parameters.ParamByName('DPCTemp').AsInteger := DPC003;    另外:DPCTemp~前面是否是要加冒號~DPCTemp這個變數需作宣告動作嗎 ADOQuery1.SQL.Add(' Values ''A01'',''Admin'',''110'',:DPCTemp,0,0)'); //答﹕1.看錯了﹐要加冒號﹐看成加引號了﹗2.不需要﹗        ========================= 我是您的朋友﹐有您真好﹗ ========================= 發表人 - cashxin2002 於 2004/12/15 15:52:49
------
忻晟
t0288542
中階會員


發表:216
回覆:254
積分:94
註冊:2004-10-06

發送簡訊給我
#9 引用回覆 回覆 發表時間:2004-12-15 15:37:03 IP:61.221.xxx.xxx 未訂閱
Hi cashxin2002 您好~    同樣也是發生此行~    Parameters.ParamByName('DPCTemp').AsInteger := DPC003; [Error] cop1.pas(245): Undeclared identifier: 'AsInteger' 麻煩您~ ^^
cashxin2002
版主


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

發送簡訊給我
#10 引用回覆 回覆 發表時間:2004-12-15 15:49:22 IP:202.62.xxx.xxx 未訂閱
您好﹗    改成這樣試試﹕
begin
  ADOQuery1.Close;
  ADOQuery1.SQL.Clear;
  ADOQuery1.SQL.Add('Insert Into COPTD ');
  ADOQuery1.SQL.Add('(TD001,TD002,TD003,TD004,TD005,TD006)');
  ADOQuery1.SQL.Add(' Values (''A01'',''Admin'',''110'',:DPCTemp,0,0)');
  ADOQuery1.Parameters.ParamByName('DPCTemp').Value := DPC003;
  ADOQuery1.ExecSQL;
end;
========================= 我是您的朋友﹐有您真好﹗ =========================
------
忻晟
t0288542
中階會員


發表:216
回覆:254
積分:94
註冊:2004-10-06

發送簡訊給我
#11 引用回覆 回覆 發表時間:2004-12-15 16:38:27 IP:61.221.xxx.xxx 未訂閱
謝謝~ cashxin2002 ok~
系統時間:2024-06-29 5:13:25
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!