麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁(yè) > 數(shù)據(jù)庫(kù) > Access > 正文

ACCESS的參數(shù)化查詢

2020-03-24 19:21:30
字體:
供稿:網(wǎng)友
最近因項(xiàng)目需要用ACCESS做數(shù)據(jù)庫(kù)開發(fā)WEB項(xiàng)目
看論壇上還許多人問及ACCESS被注入的安全問題
許多人解決的方法仍然是用Replace替換特殊字符,然而這樣做也并沒有起到太大做用
今天我就把我用ACCESS參數(shù)化查詢的一些方法和經(jīng)驗(yàn)和大家分享
希望對(duì)大家有所啟發(fā),有寫的不對(duì)的地方希望高手們多多指教ASP.NET 用OleDbCommand的new OleDbParameter創(chuàng)建參數(shù)貨查詢
ASP用Command的CreateParameter 方法創(chuàng)建參數(shù)化查詢
(SQL儲(chǔ)存過程查詢也是用這個(gè)方法建立的)ASP.NET C#語(yǔ)法OleDbParameter parm = new OleDbParameter(Name, Type, Direction, Size, Value);
(實(shí)際上它有七重載大家具體大家可以在VS.net里面就可以看到)
參數(shù)
Name 可選,字符串,代表 Parameter 對(duì)象名稱。
Type 可選,長(zhǎng)整型值,指定 Parameter 對(duì)象數(shù)據(jù)類型。
Direction 可選,長(zhǎng)整型值,指定 Parameter 對(duì)象類型。。
Size 可選,長(zhǎng)整型值,指定參數(shù)值最大長(zhǎng)度(以字符或字節(jié)數(shù)為單位)。
Value 可選,變體型,指定 Parameter 對(duì)象的值。
以下是實(shí)例,查詢news表中所有tsing發(fā)表的新聞
-------------------------------------------------------
sql="select * from newss where username=? order by id"
//注意查詢的條件均用?號(hào)表示
OleDbConnection conn = new OleDbConnection(connString);
OleDbCommand cmd = new OleDbCommand(sql,conn);
OleDbParameter parm = new OleDbParameter("temp",OleDbType.VarChar, 50);
//temp為Parameter對(duì)象可隨便定義,OleDbType.VarChar指定為字符串,長(zhǎng)度50
parm.Direction = ParameterDirection.Input;
//指定其類型輸入?yún)?shù)
cmd.Parameters.Add(parm);
cmd.Parameters["temp"].Value = "tsing";
//查詢tsing,也可以寫成cmd.Parameters[0]
conn.Open();
cmd.ExecuteReader();ASP VBSCRIPT語(yǔ)法Set parameter = command.CreateParameter (Name, Type, Direction, Size, Value)
參數(shù)同上
以下是實(shí)例,查詢news表中所有tsing發(fā)表的新聞
------------------------------------------------------
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在對(duì)參數(shù)的表達(dá)上面不同
129為adChar,1就是指示輸入?yún)?shù)(是其實(shí)是默認(rèn)值)
大家請(qǐng)參閱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函數(shù),希望對(duì)大家有幫助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
/// 構(gòu)造函數(shù),傳遞ACC參數(shù)查詢語(yǔ)句
/// /summary
/// param name="strsql" strsql字符型 /param
public accselect(string strsql)
{
sql = strsql;
}
/// summary
/// 構(gòu)造函數(shù),傳遞ACC參數(shù)查詢語(yǔ)句
/// /summary
/// param name="strsql" 參數(shù)查詢語(yǔ)句 /param
/// param name="total" 字節(jié)數(shù) /param
public accselect(string strsql, int total)
{
sql = strsql;
t = total;
}
/// summary
/// 構(gòu)造函數(shù)
/// /summary
/// param name="strsql" 參數(shù)查詢語(yǔ)句 /param
/// param name="total" 字節(jié)數(shù) /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;
}
}
}
}
//調(diào)用方法
//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
'調(diào)用方法
'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教程

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 亚洲一级片免费观看 | 日韩欧美高清一区 | 成人视屏网站 | 69性欧美高清影院 | 亚洲最新色 | 蜜桃网站在线 | 视频一区二区视频 | 国产精品自拍av | 欧美日韩在线视频一区 | 国产免费久久久久 | 久久久久久久久久亚洲 | 成人不卡在线观看 | 亚洲码无人客一区二区三区 | 欧美成人区| 中文字幕在线亚洲精品 | 色婷婷tv | 欧美91看片特黄aaaa | 日韩毛片一区二区三区 | av播播 | 精品亚洲一 | 最新欧美精品一区二区三区 | 一本视频在线观看 | www久 | 欧美久久久一区二区三区 | 九九热在线视频免费观看 | 一级电影在线观看 | 一区二区三区在线观看国产 | 91久久国产综合精品女同国语 | 久久亚洲视频网 | 日本视频在线免费观看 | 男男啪羞羞视频网站 | 一区二区三区国产视频 | 羞羞视频免费观看网站 | 狠狠干夜夜草 | 韩国草草影院 | 毛片a级毛片免费播放100 | 久久久久久久久浪潮精品 | 中日无线码1区 | 91av视频大全 | 久久精品一区二区三区国产主播 | 日本中文视频 |