ACCESS的參數化查詢,附VBSCRIPT(ASP)和C#(ASP.NET)函數第1/2頁。本站提示廣大學習愛好者:(ACCESS的參數化查詢,附VBSCRIPT(ASP)和C#(ASP.NET)函數第1/2頁)文章只能為提供參考,不一定能成為您想要的結果。以下是ACCESS的參數化查詢,附VBSCRIPT(ASP)和C#(ASP.NET)函數第1/2頁正文
最遠因項目需求用ACCESS做數據庫開發WEB項目
看論壇上還許多人問及ACCESS被注入的平安問題
許多人處理的辦法依然是用Replace交換特殊字符,但是這樣做也並沒有起到太大做用
明天我就把我用ACCESS參數化查詢的一些辦法和經歷和大家分享
希望對大家有所啟示,有寫的不對的中央希望高手們多多指教
ASP.NET 用OleDbCommand的new OleDbParameter創立參數貨查詢
ASP用Command的CreateParameter 辦法創立參數化查詢
(SQL貯存進程查詢也是用這個辦法樹立的)
ASP.NET C#語法
----------------------------------------------------------------------------
OleDbParameter parm = new OleDbParameter(Name, Type, Direction, Size, Value);
(實踐上它有七重載大家詳細大家可以在VS.net外面就可以看到)
參數
Name 可選,字符串,代表 Parameter 對象稱號。
Type 可選,長整型值,指定 Parameter 對象數據類型。
Direction 可選,長整型值,指定 Parameter 對象類型。。
Size 可選,長整型值,指定參數值最大長度(以字符或字節數為單位)。
Value 可選,變體型,指定 Parameter 對象的值。
以下是實例,查詢news表中一切tsing發表的舊事
-------------------------------------------------------
sql="select * from newss where username=? order by id"
//留意查詢的條件均用?號表示
OleDbConnection conn = new OleDbConnection(connString);
OleDbCommand cmd = new OleDbCommand(sql,conn);
OleDbParameter parm = new OleDbParameter("temp",OleDbType.VarChar, 50);
//temp為Parameter對象可隨意定義,OleDbType.VarChar指定為字符串,長度50
parm.Direction = ParameterDirection.Input;
//指定其類型輸出參數
cmd.Parameters.Add(parm);
cmd.Parameters["temp"].Value = "tsing";
//查詢tsing,也可以寫成cmd.Parameters[0]
conn.Open();
cmd.ExecuteReader();
----------------------------------------------------------------------------
ASP VBSCRIPT語法
----------------------------------------------------------------------------
Set parameter = command.CreateParameter (Name, Type, Direction, Size, Value)
參數同上
以下是實例,查詢news表中一切tsing發表的舊事
------------------------------------------------------
et conn = Server.CreateObject("Adodb.Connection")
conn.ConnectionString = connString
conn.open()
set mycmd = Server.CreateObject("ADODB.Command")
mycmd.ActiveConnection=conn
mycmd.CommandText=sql
mycmd.Prepared = true
set mypar = mycmd.CreateParameter("temp",129,1,50,"tsing")
mycmd.Parameters.Append mypar
set myrs = mycmd.Execute
---------------------------------------------------------------------------
與下面根本相反不同的中央法是asp在對參數的表達下面不同
129為adChar,1就是指示輸出參數(是其實是默許值)
大家請參閱MICROSOFT的ADOVB.Inc:
'---- ParameterDirectionEnum Values ----
Const adParamUnknown = 0
Const adParamInput = 1
Const adParamOutput = 2
Const adParamInputOutput = 3
Const adParamReturnValue = 4
'---- DataTypeEnum Values ----
Const adEmpty = 0
Const adTinyInt = 16
Const adSmallInt = 2
Const adInteger = 3
Const adBigInt = 20
Const adUnsignedTinyInt = 17
Const adUnsignedSmallInt = 18
Const adUnsignedInt = 19
Const adUnsignedBigInt = 21
Const adSingle = 4
Const adDouble = 5
Const adCurrency = 6
Const adDecimal = 14
Const adNumeric = 131
Const adBoolean = 11
Const adError = 10
Const adUserDefined = 132
Const adVariant = 12
Const adIDispatch = 9
Const adIUnknown = 13
Const adGUID = 72
Const adDate = 7
Const adDBDate = 133
Const adDBTime = 134
Const adDBTimeStamp = 135
Const adBSTR = 8
Const adChar = 129
Const adVarChar = 200
Const adLongVarChar = 201
Const adWChar = 130
Const adVarWChar = 202
Const adLongVarWChar = 203
Const adBinary = 128
Const adVarBinary = 204
Const adLongVarBinary = 205
12下一頁閱讀全文