国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 數據庫 > 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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
日本不卡视频一区二区| 久草亚洲一区| 91超碰国产在线| 超碰国产在线观看| 丁香综合五月| ·天天天天操| 热99在线观看| 中文字幕专区| 亚洲欧美国产另类首页| 精品视频二区三区| www.亚洲视频| 国产美女性感在线观看懂色av| 国产自产视频| 99爱视频在线观看| 国产在线高潮| av在线天堂| 国产欧美日韩专区| www.三级.com| 91在线中文| 国产人成在线观看| 高潮白浆视频| 青青青青在线| 亚洲国产成人综合| 国产精品久久久久久精| 日本成人在线播放| 91在线视频免费看| 国产精品作爱| 黄色av网站在线免费观看| 精品视频一区二区观看| 中文字幕在线视频观看| 美女av在线播放| av免费在线一区二区三区| 国产免费福利| 超碰在线免费播放| 天天草天天操| 国产成人精品自线拍| 交视频在线观看国产| 亚洲一区免费在线| 91九色在线看| 国产一级网站视频在线| 超碰在线网址| 狠狠操视频网| 国产在线www| 国产永久免费高清在线观看视频| 天天插天天射| 久久精品国产麻豆| 激情丁香婷婷| 最近中文字幕mv2018在线高清| 久色视频在线观看| 九九在线免费视频| 天天av天天爱| 国产福利在线播放麻豆| 国产超碰97| av中文在线| wwwww在线观看免费视频| 欧美国产中文| 中文字幕高清av| 91桃色在线| a视频在线观看免费| 欧美性猛交p30| 国产一区电影| 亚洲社区在线| 91caoporn在线| 99热免费在线观看| 久久精品无码一区二区日韩av| 日本中文字幕视频| 亚洲综合天堂网| 天天操天天射天天插| 国产精品久久久久白浆| 在线黄色国产电影| 中文字幕麻豆| 性网站在线观看| 五月婷婷开心综合| 亚洲成人福利| 国产三区在线观看| 热99re久久精品这里都是免费| 国产人成在线观看| eeuss在线观看| 免费观看久久久久| 国产福利小视频在线| 久草在线资源福利| 国产成人午夜精品| 欧美啪啪精品| 国产porn在线| 国产精彩视频在线观看免费蜜芽| 国产日本视频| 91caoporn在线| 96久久久久久| 国产精选在线视频拍拍拍| 97视频网站| 五月婷婷在线视频| 99热免费观看| 国产午夜视频在线观看| 免费在线超碰| 天天操中文字幕视频| 国产福利电影在线观看| av网址在线免费观看| 国产网站在线免费观看| 日本精品一区二区三区在线播放| 国产污视频在线| 依依成人在线| 中文字幕一区二区三区免费视频| 99爱在线观看| 国产剧情在线一区| 国产精品自产拍在线观看2019 | 国产精品剧情一区二区在线观看 | 中文字幕在线观看日本| 国产女人在线视频| 日本一二区视频| 四虎精品视频| 国产精品一区二三区| 亚洲欧洲成人| 91网页在线观看| 国产人成精品| 亚洲а∨精品天堂在线| 午夜av在线播放| 国产香蕉免费精品视频| 国产三级视频在线播放线观看| www.三区| 二区三区中文字幕| 青青久草在线| av在线不卡免费| 九九热视频在线| 国产视频福利| 人人干人人插| 免费不卡中文字幕视频 | 黄色av免费在线| 全网国产福利在线播放| 免费影视观看网站入口| 国产精选在线视频拍拍拍| 国产精品天堂| 2021av在线| 一本大道香蕉8中文在线视频| baoyu777.永久免费视频| 在线视频中文字幕第一页| 欧洲一区av| 国产精品一区二区三区视频网站| 国产盗摄一区二区| 在线观看av网站| 国产一级片麻豆| 日本欧洲一区| 国产人成精品| 丁香六月婷婷| 18激情网站| 国内精品一区视频| av丝袜在线| 中中文字幕av在线| 性网站在线观看| 国产免费视频在线| 在线观看av中文| 1区2区3区在线| 在线免费日韩| 欧美午夜电影一区二区三区| 欧美96在线| 国产亚洲精品久久久久久青梅| av黄色在线观看| 在线天堂av| 中文日本在线观看| 国产网站在线免费观看| 麻豆网站在线| 国产女王在线**视频 | 97操碰视频| 超碰在线网址| 在线中文字幕观看| 国产人成在线观看| av在线你懂的| 国产91在线视频蝌蚪| 国产精品一区二区三区视频网站| www.香蕉视频在线观看| 青青草视频在线免费观看| 国产对白在线| 亚洲精品在线播放视频| 开心激情五月婷婷| 国产精选一区二区三区不卡催乳| jlzzjlzz欧美| 国产写真视频在线观看| 国产一起色一起爱| 国产精品入口免费麻豆| 免费不卡中文字幕视频| 俺来俺也去www色在线观看| 免费在线看v| 另类高清dbsm日本tvav| 午夜视频在线| 国产youjizz在线| 国产二级片在线| 国产视频福利| 精品电影在线| 天堂网中文在线| 国产精品天堂| 亚洲尤物在线视频| 国产精品天堂| av在线你懂的| 国产黄视频在线观看| 在线一区观看| 最新中文字幕在线| 麻豆网站在线| 亚洲日本伊人| 91中文字幕| 国产精品入口麻豆免费| 免费不卡中文字幕视频|