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

Parameters與FieldByName的差別為何!?

答題得分者是:P.D.
solid098
一般會員


發表:16
回覆:14
積分:6
註冊:2007-02-15

發送簡訊給我
#1 引用回覆 回覆 發表時間:2007-03-16 19:23:07 IP:59.117.xxx.xxx 訂閱
adoquery1.Parameters.ParamByName('s1').Value:=s1;
adoquery1.FieldByName('s1').AsString:=trim(exid1.text);
請問各位高手~~這兩段程式用法差別在哪!?
編輯記錄
dllee 重新編輯於 2007-04-21 19:11:10, 註解 修改文章分類由 無 -> 問題, 提問時, 請記得選擇 [問題] 分類, 才能把分數給辛苦答題的會員, 謝謝您的配合‧‧
P.D.
版主


發表:603
回覆:4038
積分:3874
註冊:2006-10-31

發送簡訊給我
#2 引用回覆 回覆 發表時間:2007-03-17 01:43:21 IP:61.67.xxx.xxx 未訂閱
parambyanem --> 傳遞指定變數給指定欄位參數使用, 例如

select * from table1 where myfield >= :var1
parambyaname('var1').value:= 100
經sql轉換就成了 select * from table1 where myfield>= 100

fieldbyanem --> 傳遞欄位值給指定變數或將指定值傳遞給欄位變數
select field1, field2, field3 from table1
fieldbyname('field1').value:= 100
var1:= fieldbyname('field1').value;
leonli80
一般會員


發表:29
回覆:27
積分:11
註冊:2006-08-01

發送簡訊給我
#3 引用回覆 回覆 發表時間:2007-04-08 16:19:59 IP:218.81.xxx.xxx 訂閱
我還是比較喜歡用 adoquery1.FieldByName('s1').AsString 這種方式,因爲這種方式寫出來的程式,在資料庫結構有異動的情況下,程式會修改得比較少。
eaglewolf
資深會員


發表:4
回覆:268
積分:429
註冊:2006-07-06

發送簡訊給我
#4 引用回覆 回覆 發表時間:2007-04-13 18:09:18 IP:211.75.xxx.xxx 訂閱
誤會大囉
parameter 是用在把值傳給SQL Command 本身內的變數
FieldByName 是用來存取RecordSet內某筆資料的某個欄位的資料
舉例來說:
strSQLCommand.CommandText := 'Select * From A Where a = :pa';
strSQLCommand.parameters.parambyname('pa').value := 'A';
//上述兩行相當於 strSQLCommand.CommandText := 'Select * From A Where a = ''A''';
rsRecord = cmCommand.open(strCommand);
rsRecord.Edit;
rsRecord.FieldByName('b').Value := 'B';
rsRecord.Post;

------
先查HELP
再查GOOGLE
最後才發問

沒人有義務替你解答問題
在標題或文章中標明很急
並不會增加網友回答速度

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