中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)絡編程 > ACCESS的參數(shù)化查詢
php項目打包 回到列表 Jsp頁面實現(xiàn)文件上傳下載
 ACCESS的參數(shù)化查詢

作者:moby 時間: 2008-01-09 文檔類型:原創(chuàng) 來自:藍色理想

最近因項目需要用ACCESS做數(shù)據(jù)庫開發(fā)WEB項目
看論壇上還許多人問及ACCESS被注入的安全問題
許多人解決的方法仍然是用Replace替換特殊字符,然而這樣做也并沒有起到太大做用
今天我就把我用ACCESS參數(shù)化查詢的一些方法和經(jīng)驗和大家分享
希望對大家有所啟發(fā),有寫的不對的地方希望高手們多多指教

ASP.NET 用OleDbCommand的new OleDbParameter創(chuàng)建參數(shù)貨查詢
ASP用Command的CreateParameter 方法創(chuàng)建參數(shù)化查詢
(SQL儲存過程查詢也是用這個方法建立的)

ASP.NET C#語法

OleDbParameter parm = new OleDbParameter(Name, Type, Direction, Size, Value);
(實際上它有七重載大家具體大家可以在VS.net里面就可以看到)
參數(shù)
Name        可選,字符串,代表 Parameter 對象名稱。
Type        可選,長整型值,指定 Parameter 對象數(shù)據(jù)類型。
Direction   可選,長整型值,指定 Parameter 對象類型。。
Size        可選,長整型值,指定參數(shù)值最大長度(以字符或字節(jié)數(shù)為單位)。
Value       可選,變體型,指定 Parameter 對象的值。
以下是實例,查詢news表中所有tsing發(fā)表的新聞
  -------------------------------------------------------
  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;
  //指定其類型輸入?yún)?shù)
  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)
參數(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在對參數(shù)的表達上面不同
  129為adChar,1就是指示輸入?yún)?shù)(是其實是默認值)
大家請參閱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ù),希望對大家有幫助

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>
        /// 構(gòu)造函數(shù),傳遞ACC參數(shù)查詢語句
        /// </summary>
        /// <param name="strsql">strsql字符型</param>
        public accselect(string strsql)
        {
            sql = strsql;
        }
        /// <summary>
        /// 構(gòu)造函數(shù),傳遞ACC參數(shù)查詢語句
        /// </summary>
        /// <param name="strsql">參數(shù)查詢語句</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ù)查詢語句</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

經(jīng)典論壇討論
http://bbs.blueidea.com/thread-2822670-1-1.html

本文鏈接:http://www.95time.cn/tech/program/2008/5267.asp 

出處:藍色理想
責任編輯:moby

◎進入論壇網(wǎng)絡編程版塊參加討論

相關(guān)文章 更多相關(guān)鏈接
C#中的委托和事件
Membership角色與權(quán)限管理
[.net]windows控件實現(xiàn)水印
實戰(zhàn)access+php的留言版
[php]配置,鏈接access數(shù)據(jù)庫
作者文章 更多作者文章
像素蘋果的手工經(jīng)典娃娃
"精英彙"高端創(chuàng)意人沙龍開始報名
"方正獎"中文字體及海報設計作品
CGArt第十一期震撼發(fā)行
香港4A廣告商會50華誕 電子年鑒
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設計比賽 網(wǎng)頁制作 web標準 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大!熬•自然”設計大賽開啟
國際體驗設計大會7月將在京舉行
中國國防科技信息中心標志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule

藍色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關(guān)法律法規(guī)
·承擔一切因您的行為而直接或間接導致的民事或刑事法律責任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2