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

首頁 > 數據庫 > Access > 正文

ACCESS的參數化查詢

2020-03-24 19:21:30
字體:
來源:轉載
供稿:網友
最近因項目需要用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
html' target='_blank'>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 本文作者:html教程

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品吊钟奶在线| 日韩高清人体午夜| 久久久国产视频91| 中文字幕日韩专区| 欧美另类交人妖| 欧美日韩在线一区| 色综合影院在线| 国产日韩精品在线| 国产一区二区三区日韩欧美| 亚洲美女在线看| 国产丝袜一区视频在线观看| 亚洲色图在线观看| 自拍偷拍免费精品| 亲爱的老师9免费观看全集电视剧| www.久久草.com| 亚洲影视中文字幕| 亚洲男人第一av网站| 久久久这里只有精品视频| 亚洲视频在线视频| 欧美色videos| 日韩一区在线视频| 日韩av理论片| 亚洲国产高清自拍| 久久精品亚洲94久久精品| 欧美精品久久久久久久久| 亚洲一区二区三区sesese| 国产精品麻豆va在线播放| 欧美日韩裸体免费视频| 久久99亚洲精品| 国产精品视频网址| 狠狠躁18三区二区一区| 欧美激情第6页| 亚洲天堂av综合网| 欧美乱人伦中文字幕在线| 亚洲国产欧美一区二区三区同亚洲| 国产v综合ⅴ日韩v欧美大片| 亚洲人成网站在线播| 欧美在线www| 精品国产老师黑色丝袜高跟鞋| 欧美中文在线字幕| 国产欧美在线看| 97涩涩爰在线观看亚洲| 国产精品欧美激情在线播放| 色视频www在线播放国产成人| 精品人伦一区二区三区蜜桃免费| 国产日韩中文在线| www.日韩欧美| 国产剧情久久久久久| 亚洲精品美女在线观看播放| 亚洲另类激情图| 日韩av综合网| 日韩中文字幕精品视频| 国产日韩中文字幕| 性欧美长视频免费观看不卡| 夜色77av精品影院| 国产欧美 在线欧美| 久久久久国产精品免费网站| 超在线视频97| 国产有码一区二区| 国产精品久久av| 日韩最新免费不卡| 欧美午夜激情在线| 黑人巨大精品欧美一区二区三区| 国产欧美在线看| 精品日本高清在线播放| 91大神在线播放精品| 日韩电影大全免费观看2023年上| 欧美在线视频免费观看| 亚洲综合在线做性| 日韩亚洲欧美中文高清在线| 亚洲精品国产精品乱码不99按摩| 国产成人一区二区| 欧美精品激情blacked18| 色午夜这里只有精品| 国产aaa精品| 国模gogo一区二区大胆私拍| 日韩欧美中文字幕在线播放| 国产一区二区三区日韩欧美| 美女国内精品自产拍在线播放| 亚洲深夜福利网站| 精品视频在线导航| 亚洲精品动漫100p| 久久精品国产免费观看| 懂色av影视一区二区三区| www.亚洲男人天堂| 最新69国产成人精品视频免费| 九九九热精品免费视频观看网站| 日韩网站在线观看| 欧美精品videos另类日本| 亚洲精品不卡在线| 一个色综合导航| 精品av在线播放| 亚洲自拍偷拍一区| 日韩福利在线播放| 黄色91在线观看| 日韩视频在线免费观看| 伦理中文字幕亚洲| 日韩在线观看视频免费| 最近2019中文字幕mv免费看| 亚洲黄色av女优在线观看| 国产精品一区二区3区| 精品国产乱码久久久久久婷婷| 国产欧美精品在线播放| 国产欧美日韩精品专区| 91亚洲国产成人精品性色| 国产女人18毛片水18精品| 日本道色综合久久影院| 97国产精品视频人人做人人爱| 国产精品久久久久久av下载红粉| 国产精品网站视频| 91精品视频免费观看| 国产精品精品一区二区三区午夜版| 国产欧美精品在线| 亚洲三级黄色在线观看| 欧美极品少妇与黑人| 国产suv精品一区二区三区88区| 亚洲精品免费一区二区三区| 久久国内精品一国内精品| 日韩精品在线第一页| 成人网在线免费看| 精品久久中文字幕久久av| 人人爽久久涩噜噜噜网站| www.国产一区| 懂色aⅴ精品一区二区三区蜜月| 欧美性猛交xxxx乱大交极品| 日韩美女视频免费看| 91精品国产自产91精品| 夜夜嗨av色一区二区不卡| 精品日本美女福利在线观看| 亚洲一区二区三| 久久免费在线观看| 欧洲日本亚洲国产区| 国产成人久久久| 欧美激情性做爰免费视频| 亚洲最大激情中文字幕| 亚洲精品久久在线| 奇门遁甲1982国语版免费观看高清| 亚洲精品有码在线| 亚洲va久久久噜噜噜| 欧美性理论片在线观看片免费| 欧美国产在线视频| 日韩视频永久免费观看| 精品久久久久久中文字幕一区奶水| 久久夜色精品国产| 欧美激情国产精品| 中文字幕亚洲色图| 欧美专区中文字幕| 久久久久久高潮国产精品视| 久久久久久久一区二区| 最近2019中文字幕mv免费看| 国产视频精品久久久| 久久精品亚洲一区| 成人激情在线观看| 国产脚交av在线一区二区| 日本成人激情视频| 亚洲欧美国产精品久久久久久久| 国产亚洲在线播放| 96精品久久久久中文字幕| 亚洲性猛交xxxxwww| 久久久久成人精品| 久久久999精品视频| 亚洲午夜精品久久久久久久久久久久| 亚洲精品福利在线观看| 欧美多人爱爱视频网站|