亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > Access > 正文

ACCESS實用技巧:ACCESS的參數化查詢

2024-09-07 19:03:41
字體:
來源:轉載
供稿:網友

最近因項目需要用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

附我寫的C#類,和VBSCRIPT函數,希望對大家有幫助

using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Data.OleDb;
namespace acc_select
{
/// <summary>
/// accselect 的摘要說明
/// </summary>
public class accselect
{
//"Provider=Microsoft.Jet.OLEDB.4.0; Data Source=d:/dq/db1.mdb"
private string conn = ConfigurationManager.ConnectionStrings["tsingConnectionString"].ToString();
public string sql = string.Empty;
public int t = 4;
public object v = null;
public accselect()
{
}

/// <summary>
/// 構造函數,傳遞ACC參數查詢語句
/// </summary>
/// <param name="strsql">strsql字符型</param>
public accselect(string strsql)
{
sql = strsql;
}
/// <summary>
/// 構造函數,傳遞ACC參數查詢語句
/// </summary>
/// <param name="strsql">參數查詢語句</param>
/// <param name="total">字節數</param>


public accselect(string strsql, int total)
{
sql = strsql;
t = total;
}
/// <summary>
/// 構造函數
/// </summary>
/// <param name="strsql">參數查詢語句</param>
/// <param name="total">字節數</param>
/// <param name="value">OBJECT值</param>
public accselect(string strsql, int total, object value)
{


sql = strsql;
t = total;
v = value;
}
/// <summary>
/// getOdd方法返回OleDbDataReader
/// </summary>
/// <param name="odt">定義OleDbType類型</param>
/// <returns></returns>
public OleDbDataReader getOdd(OleDbType odt)
{
OleDbConnection conns = new OleDbConnection(this.conn);
OleDbCommand cmd = new OleDbCommand(this.sql, conns);


OleDbParameter parm = new OleDbParameter("temp", odt, this.t);
parm.Direction = ParameterDirection.Input;
cmd.Parameters.Add(parm);
cmd.Parameters[0].Value = this.v;
conns.Open();
OleDbDataReader oda = cmd.ExecuteReader();
cmd.Dispose();
return oda;
}
string Sql
{
get


{
return sql;
}
set
{
sql = value;
}
}
int T
{
get
{
return t;
}
set
{
t = value;
}
}
object V
{
get
{
return v;
}
set
{
v = value;

}
}
}
}
//調用方法
//accselect acc = new accselect();
//acc.sql = "select * from dtt where d_id=?";
//acc.t = 10;
//acc.v = 1;
//OleDbDataReader oda = acc.getOdd(OleDbType.VarChar);
//Repeater1.DataSource = oda;
//Repeater1.DataBind();


function acc_sql(sql,adotype,adodct,strlong,values)
dim connstring,mycmd,myrs,conn

connString="Provider=Microsoft.Jet.OLEDB.4.0; Data Source=" & Server.MapPath("db1.mdb")
set 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",adotype,adodct,strlong,values)
mycmd.Parameters.Append mypar
set myrs = mycmd.Execute
set acc_sql=myrs
end function
’調用方法
’dim rs
’sql="select * from users where id=? order by id"
’set rs=acc_sql(sql,3,1,4,1)
’if not rs.eof then
’response.Write(rs(1))
’end if


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲free性xxxx护士hd| 在线看片第一页欧美| 在线电影欧美日韩一区二区私密| 91国内精品久久| 欧美性xxxx极品高清hd直播| 日韩美女视频在线观看| 在线视频欧美性高潮| 国产精品国产自产拍高清av水多| 97色在线视频观看| 亚洲国产精品成人av| 欧美日韩高清区| 久久亚洲综合国产精品99麻豆精品福利| 亚洲人成网站在线播| 欧美俄罗斯乱妇| 久久天天躁狠狠躁夜夜av| 热99精品里视频精品| 国产黑人绿帽在线第一区| 亚洲最新视频在线| 亚洲国产精品国自产拍av秋霞| 亚洲午夜久久久久久久| 国产精品免费久久久| 精品av在线播放| 91精品一区二区| 色偷偷噜噜噜亚洲男人的天堂| 精品久久香蕉国产线看观看gif| 91精品免费看| 亚洲人成在线观看| 日韩av一区在线观看| 91中文字幕在线| 日韩理论片久久| 国产精品最新在线观看| 国产精品444| 欧美性猛交xxxx免费看久久久| 久久久久成人精品| 69久久夜色精品国产7777| 国产亚洲一区精品| 亚洲欧洲免费视频| 色婷婷综合久久久久| 91九色蝌蚪国产| 69久久夜色精品国产69| 精品国产福利视频| 亚洲欧美www| 一区二区三区亚洲| 91沈先生作品| 国产精品久久久久久久久男| 亚洲欧美一区二区三区久久| 欧美亚洲日本黄色| 国产精品久久久久久久久久尿| 国产日韩综合一区二区性色av| 日韩中文字幕免费视频| 欧美国产视频一区二区| 国产香蕉一区二区三区在线视频| 国产精品视频在线观看| 色妞色视频一区二区三区四区| 狠狠躁天天躁日日躁欧美| 国语自产在线不卡| 亚洲片国产一区一级在线观看| 在线播放国产一区中文字幕剧情欧美| 亚洲国产精品久久| 亚洲国产91精品在线观看| 久久久久久久91| 欧美亚洲日本黄色| 国模吧一区二区| 欧美一级电影免费在线观看| 亚洲三级黄色在线观看| 97在线视频免费观看| 国产精品久久91| 亚洲精品成人免费| 亚洲欧美在线一区二区| 成人在线一区二区| 欧美高清自拍一区| xxxx欧美18另类的高清| 久久久久久久999精品视频| 国产大片精品免费永久看nba| 成人黄在线观看| 黑人精品xxx一区一二区| 午夜精品久久久久久久99热| 欧美成人午夜激情| 中文字幕日韩在线视频| 日本精品视频网站| 国产成人福利网站| 亚洲免费成人av电影| 久久久在线观看| 欧洲一区二区视频| 欧美日韩国产麻豆| 亚洲精品自拍视频| 欧美亚州一区二区三区| 26uuu另类亚洲欧美日本一| 日韩av片永久免费网站| 日韩av网站电影| 日韩第一页在线| 成人免费视频在线观看超级碰| 91久久精品在线| 国产午夜精品全部视频在线播放| 欧美中文字幕在线| 一个人看的www欧美| 2024亚洲男人天堂| 俺也去精品视频在线观看| 日韩精品极品视频| 久久久久999| 91地址最新发布| 国产精品99久久久久久人| 日韩美女福利视频| 日韩国产欧美精品一区二区三区| 国产精品人人做人人爽| 日韩成人av网| 亚洲丝袜av一区| 亚洲欧美国产精品专区久久| 亚洲国产美女精品久久久久∴| 秋霞午夜一区二区| 日韩中文字幕在线免费观看| 欧美高跟鞋交xxxxxhd| 国语自产偷拍精品视频偷| 性欧美亚洲xxxx乳在线观看| 操日韩av在线电影| 亚洲肉体裸体xxxx137| 国产成人综合精品在线| 国产日韩换脸av一区在线观看| 国产精品91在线| 亚洲精品色婷婷福利天堂| 正在播放欧美视频| 欧美精品在线免费播放| 亚洲国产成人精品电影| 日韩在线视频中文字幕| 亚洲欧美日韩一区二区在线| 国产一区玩具在线观看| 国产97人人超碰caoprom| 欧美精品在线免费播放| 91九色视频导航| 亚洲电影在线看| 成人免费网站在线观看| 日韩美女主播视频| 国产精品久久久久9999| 欧美午夜激情在线| 久久久久久国产精品美女| 国产日韩在线看片| 97久久超碰福利国产精品…| 不卡av在线网站| 欧美一区二粉嫩精品国产一线天| 亚洲最大福利网| 国产欧美va欧美va香蕉在| 亚洲精品一区在线观看香蕉| 亚洲美女www午夜| 欧美极品xxxx| 亚洲第一网中文字幕| 国a精品视频大全| 国产午夜精品全部视频在线播放| 久久99精品久久久久久琪琪| 日韩av电影中文字幕| 欧美一区二区影院| 日韩av免费在线| 亚洲人成网站777色婷婷| 亚洲精品一区二区三区不| 国产精品福利片| 亚洲精品国产综合区久久久久久久| 亚洲欧洲日产国码av系列天堂| 成人免费网站在线观看| 亚洲成色777777在线观看影院| 国产一区二区黄| 国产精品欧美激情| 国产成人欧美在线观看| 精品色蜜蜜精品视频在线观看| 亚洲国产精品久久久久秋霞蜜臀| 国产亚洲精品va在线观看|