解讀ACCESS的參數化查詢_Access數據庫教程
推薦:如何在 Access 里使用查詢建立 存儲過程/視圖, 并使用 ASP 執行摘要: 本文演示了 使用 Access查詢 構造類似于 MSSQL 存儲過程的功能, 并在 ASP 中操作插入數據,顯示數據功能. 目錄: 1. 在 Access 查詢里建表, 名 tt 2. 在 Access 查詢里新建查詢, 內容為:... 3. 在 ASP 里使用 tt_insertParm 添加10條記錄到 表tt 3.1 構造
最近因項目需要用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:
分享:如何設置Access項目中檢索的記錄數在使用 Microsoft Access 項目的窗體或數據表中的數據時,為了提高性能,可以設置從 SQL Server 數據庫下載的最大記錄數。 1.在“導航”模式中打開數據表或窗體。 2.執行下列操作之一: 從“記錄”菜單中選擇“最大記錄數”。 單擊導航按鈕右側的“最大記錄
- 相關鏈接:
- 教程說明:
Access數據庫教程-解讀ACCESS的參數化查詢。