自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

VB.NET使用MS Access技術(shù)指導(dǎo)

開(kāi)發(fā) 后端
VB.NET使用MS Access對(duì)于開(kāi)發(fā)人員來(lái)說(shuō)是一個(gè)比較重要的操作技巧。因?yàn)镸S是一個(gè)功能全面的數(shù)據(jù)庫(kù)系統(tǒng)。很好的處理了二者的關(guān)系,可以對(duì)我們的程序起到很到的作用。

大家通過(guò)對(duì)VB.NET的學(xué)習(xí),應(yīng)該會(huì)清楚的了解到這款語(yǔ)言的特殊性。其完全面相對(duì)象,編寫(xiě)方式簡(jiǎn)單靈活,可以為開(kāi)發(fā)人員創(chuàng)造一個(gè)良好的編程環(huán)境。首先先來(lái)看看VB.NET使用MS Access的相關(guān)技巧。#t#

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

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

存儲(chǔ)過(guò)程如何在Access里工作?

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

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

VB.NET使用MS Access創(chuàng)建存儲(chǔ)過(guò)程

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

  1. "CREATE PROC procProductsList 
    AS SELECT * FROM Products;" 

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

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

  1. "CREATE PROC procProducts
    DeleteItem(inProductsID LONG)" & _  
  2. "AS DELETE FROM Products 
    WHERE 
    ProductsID = inProductsID;" 

 

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

下項(xiàng)兩個(gè)分開(kāi)的語(yǔ)句顯示了如何為Product表創(chuàng)建一個(gè)add和一個(gè)update儲(chǔ)存過(guò)程。注意,為了文章的簡(jiǎn)短,過(guò)程中沒(méi)有包括所有的字段:

  1. "CREATE PROC procProductsAddItem
    (inProductName VARCHAR(40), " & _  
  2. "inSupplierID LONG, inCategoryID 
    LONG) " & _  
  3. "AS INSERT INTO Products 
    (ProductName, SupplierID, CategoryID) 
    " & _  
  4. "Values (inProductName, inSupplierID,
     inCategoryID);"  
  5. "CREATE PROC procProductsUpdateItem
    (inProductID LONG, " & _  
  6. " inProductName VARCHAR(40)) " & _  
  7. "AS UPDATE Products SET ProductName 
    inProductName " & _  
  8. " WHERE ProductID = inProductID

 

注意:當(dāng)參數(shù)數(shù)量超過(guò)一個(gè)的時(shí)候,用逗號(hào)分開(kāi)。

VB.NET使用MS Access中的限制

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

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

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

Access無(wú)法存取臨時(shí)表。

我懷疑在很多Transaction SQL里有的選項(xiàng)在Access里是沒(méi)有的,因?yàn)樗皇荰ransaction SQL兼容的。

VB.NET使用MS Access結(jié)論

希望這篇文章能提供在一個(gè)幾乎是Access的未公開(kāi)領(lǐng)域的一些指引,而對(duì)JET引擎則沒(méi)有多做探討。 如果需要知道ADO.NET代碼在 CreateStoredProc 子程序里是如何工作的更多信息,請(qǐng)參見(jiàn)Gurneet Singh 寫(xiě)的Getting Started with ADO.NET。文章所有代碼請(qǐng)到下載欄目下載。

責(zé)任編輯:曹凱 來(lái)源: 博客園
相關(guān)推薦

2010-01-11 16:04:10

VB.NET使用wit

2009-10-14 17:08:44

VB.NET使用Fil

2009-10-26 15:57:07

VB.NET使用Ora

2009-11-03 13:48:02

VB.NET枚舉

2009-10-13 17:31:50

VB.NET Acce

2009-10-28 14:25:17

VB.NET Sock

2010-05-18 11:13:54

Subversion使

2009-10-28 09:21:19

VB.NET技術(shù)

2010-01-07 15:57:02

VB.NET ForEach

2009-10-12 16:39:59

OracleTransVB.NET使用

2009-10-16 11:38:47

VB.NET使用Ali

2009-10-28 12:28:52

VB.NET資源使用

2009-11-03 11:27:30

VB.NET界面

2009-11-02 13:54:27

VB.NET shel

2009-10-20 10:29:30

VB.NET使用Sor

2009-10-13 15:20:02

VB.NET使用Dra

2009-10-16 10:14:26

VB.NET使用Fil

2009-10-16 14:07:18

VB.NET使用Mon

2010-01-18 18:20:49

VB.NET使用API

2009-10-12 13:11:48

VB.NET使用線(xiàn)程
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)