国产一级a片免费看高清,亚洲熟女中文字幕在线视频,黄三级高清在线播放,免费黄色视频在线看

打開APP
userphoto
未登錄

開通VIP,暢享免費電子書等14項超值服

開通VIP
MS Access中使用存儲過程
自從Access2000以來,Access已經(jīng)具備了存儲過程的功能,而且是Jet 4 Database Engine自帶的。如果你習(xí)慣于在SQL SERVER里使用存儲過程,那么你就會很熟悉它們?nèi)绾卧贏ccess里使用。但是要記住有一些限制。我會稍后作討論。
  

   最新發(fā)布的MS Access中,微軟已經(jīng)盡努力使這種產(chǎn)品成為一個真正全功能的關(guān)系數(shù)據(jù)庫系統(tǒng)。存儲過程,一個通常和企業(yè)數(shù)據(jù)庫系統(tǒng)例如SQLServer相關(guān)的功能,現(xiàn)在也可以在Access里找到了。自從Access2000以來,Access已經(jīng)具備了存儲過程的功能,而且是Jet 4 Database Engine自帶的。如果你習(xí)慣于在SQL SERVER里使用存儲過程,那么你就會很熟悉它們?nèi)绾卧贏ccess里使用。但是要記住有一些限制。我會稍后作討論。


這篇文章分成兩個部份。第一部份會詳細描述如何在使用ADO.NET和Visual Basic.NET在Access里創(chuàng)建存儲過程。第二部份則會示范如何利用在第一部分創(chuàng)建的存儲過程來創(chuàng)建一個數(shù)據(jù)訪問層,并且在你自己的應(yīng)用程序中使用。這篇文章中的代碼已經(jīng)在Access2002種測試通過,即使如此,它也應(yīng)該能運行于Access2000。

存儲過程如何在Access里工作?

不像在Access里的其它的對象,存儲過程沒有用戶界面,并且不能在Access的界面里創(chuàng)建。 要建立它們的方法只有編碼。我將示范如何在ADO.NET中實現(xiàn)這些代碼。

當一個存儲過程被添加到Access數(shù)據(jù)庫時,JET Engine會把存儲過程轉(zhuǎn)換到一個查詢對象。對一個Access開發(fā)者而言,這就象編寫一個簡單的查詢,是不必要的工作。然而,它確實有它的優(yōu)點??紤]一下,一個應(yīng)用系統(tǒng)必須為了分開Access版和SQL SERVER版而分成2個系統(tǒng)的情況吧。使用存儲過程會使為應(yīng)用程序的數(shù)據(jù)庫訪問層寫代碼變得更容易,程序在不同的版本之間區(qū)別很小。

創(chuàng)建存儲過程

為了示范,我會先顯示如何使用SQL語句來創(chuàng)建存儲過程。 在文章末尾我會給列出需要在數(shù)據(jù)庫執(zhí)行的所有語句的代碼。當使用和Access包含的Northwind數(shù)據(jù)庫時,它會創(chuàng)建4個存儲過程。 它們都集中于Prodcut表,讓我們從最容易的那個開始: 選擇表格里所有行的數(shù)據(jù)。 為了創(chuàng)建這個存儲過程,在數(shù)據(jù)庫執(zhí)行下列SQL語句:

"CREATE PROC procProductsList AS SELECT * FROM Products;"

語句“CREATE PROC procCustomerList”是實際上創(chuàng)建存儲過程的部份。 在”AS”下面的部分可以為任何有效的SQL語句。

經(jīng)常性的,你會需要傳遞參數(shù)到存儲過程去用于查詢。 例如你可能想要根據(jù)某一個ProductID刪除一個記錄。 下列存儲過程顯示如何實現(xiàn)這個目的:

"CREATE PROC procProductsDeleteItem(inProductsID LONG)" & _
"AS DELETE FROM Products WHERE ProductsID = inProductsID;"

在第一行,注意CREATE PROC聲明右邊的括號。 有一個定義為長整型的參數(shù)。 這是需要你輸入的變量,用于刪除記錄。

下項兩個分開的語句顯示了如何為Product表創(chuàng)建一個add和一個update儲存過程。注意,為了文章的簡短,過程中沒有包括所有的字段:


"CREATE PROC procProductsAddItem(inProductName VARCHAR(40), " & _
"inSupplierID LONG, inCategoryID LONG) " & _
"AS INSERT INTO Products (ProductName, SupplierID, CategoryID) " & _
"Values (inProductName, inSupplierID, inCategoryID);"

"CREATE PROC procProductsUpdateItem(inProductID LONG, " & _
" inProductName VARCHAR(40)) " & _
"AS UPDATE Products SET ProductName = inProductName " & _
" WHERE ProductID = inProductID;

注意:當參數(shù)數(shù)量超過一個的時候,用逗號分開。

限制

在這里,你可能會碰到一些限制,尤其是如果當你已經(jīng)非常習(xí)慣于SQL SERVER的強大功能的時候。

不能使用輸出參數(shù)。

不要使用@字符。 @字符通常用于Transaction SQL( SQL SERVER),代表一個本地變量 。 Access不總是會轉(zhuǎn)換這個字符, 有時會將它省略。這個問題可能導(dǎo)致很難找的BUG, 會使你多掉幾把頭發(fā)。

Access無法存取臨時表。


我懷疑在很多Transaction SQL里有的選項在Access里是沒有的,因為它不是Transaction SQL兼容的。

結(jié)論

希望這篇文章能提供在一個幾乎是Access的未公開領(lǐng)域的一些指引,而對JET引擎則沒有多做探討。 如果需要知道ADO.NET代碼在 CreateStoredProc 子程序里是如何工作的更多信息,請參見Gurneet Singh 寫的Getting Started with ADO.NET。

本站僅提供存儲服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊舉報。
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
Access數(shù)據(jù)庫執(zhí)行sql語句
VB實現(xiàn)SQL Server 2000存儲過程調(diào)用
.NET開發(fā)實戰(zhàn)之ADO.NET中的類
SQL Server 2008數(shù)據(jù)庫實用教程-第12章
將Access數(shù)據(jù)庫移植到SQL Server
Access/VBA/Excel-Access表及字段創(chuàng)建-03
更多類似文章 >>
生活服務(wù)
分享 收藏 導(dǎo)長圖 關(guān)注 下載文章
綁定賬號成功
后續(xù)可登錄賬號暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點擊這里聯(lián)系客服!

聯(lián)系客服