數(shù)據(jù)庫訪問技術(shù)(ADO-NET)_第1頁
數(shù)據(jù)庫訪問技術(shù)(ADO-NET)_第2頁
數(shù)據(jù)庫訪問技術(shù)(ADO-NET)_第3頁
數(shù)據(jù)庫訪問技術(shù)(ADO-NET)_第4頁
數(shù)據(jù)庫訪問技術(shù)(ADO-NET)_第5頁
已閱讀5頁,還剩25頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)

文檔簡介

數(shù)據(jù)庫訪問技術(shù)ADO.NETADO.NET的起源1998年起,因為Web應(yīng)用程序的竄起,大大改變了許多應(yīng)用程序的設(shè)計方式,傳統(tǒng)的數(shù)據(jù)庫連線保存設(shè)計法無法適用于此類應(yīng)用程序,這讓ADO應(yīng)用程序遇到了很大的瓶頸,也讓微軟開始思考讓資料集(Resultset,在ADO中稱為Recordset)能夠離線化的能力,以及能在用戶端創(chuàng)建一個小型數(shù)據(jù)庫的概念,這個概念就是中離線型資料模型(disconnecteddatamodel)的基礎(chǔ),而在ADO的使用情形來看,數(shù)據(jù)庫連線以及資源耗用的情形較嚴(yán)重(像是Server-sidecursor或是Recordset.Open會保持連線狀態(tài)),在中也改良了這些組件,構(gòu)成了能夠減少數(shù)據(jù)庫連線和資源使用量的功能。XML的使用也是這個版本的重要發(fā)展之一。2000年,微軟的Microsoft.NET計劃開始成形,許多的微軟產(chǎn)品都冠上.NET的標(biāo)簽,ADO+也不例外,改名為并包裝到.NETFramework類別庫中,成為.NET平臺中唯一的資料存取組件。ADO.NET簡介ADO.NET是一組向.NETFramework程序員公開數(shù)據(jù)訪問服務(wù)的類。ADO.NET為創(chuàng)建分布式數(shù)據(jù)共享應(yīng)用程序提供了一組豐富的組件。它提供了對關(guān)系數(shù)據(jù)、XML和應(yīng)用程序數(shù)據(jù)的訪問,因此是.NETFramework中不可缺少的一部分。ADO.NET支持多種開發(fā)需求,包括創(chuàng)建由應(yīng)用程序、工具、語言或Internet瀏覽器使用的前端數(shù)據(jù)庫客戶端和中間層業(yè)務(wù)對象。ADO.NET簡介ADO.NET提供對諸如SQLServer和XML這樣的數(shù)據(jù)源以及通過OLEDB和ODBC公開的數(shù)據(jù)源的一致訪問。共享數(shù)據(jù)的使用方應(yīng)用程序可以使用ADO.NET連接到這些數(shù)據(jù)源,并可以檢索、處理和更新其中包含的數(shù)據(jù)。ADO.NET通過數(shù)據(jù)處理將數(shù)據(jù)訪問分解為多個可以單獨使用或一前一后使用的不連續(xù)組件。ADO.NET包含用于連接到數(shù)據(jù)庫、執(zhí)行命令和檢索結(jié)果的.NETFramework數(shù)據(jù)提供程序。這些結(jié)果或者被直接處理,放在ADO.NETDataSet對象中以便以特別的方式向用戶公開,并與來自多個源的數(shù)據(jù)組合;或者在層之間傳遞。DataSet對象也可以獨立于.NETFramework數(shù)據(jù)提供程序,用于管理應(yīng)用程序本地的數(shù)據(jù)或源自XML的數(shù)據(jù)。ADO.NET的結(jié)構(gòu)及組件ADO.NET用于訪問和操作數(shù)據(jù)的兩個主要組件是.NETFramework數(shù)據(jù)提供程序和DataSet。NETFramework數(shù)據(jù)提供程序.NETFramework數(shù)據(jù)提供程序是專門為數(shù)據(jù)操作以及快速、只進(jìn)、只讀訪問數(shù)據(jù)而設(shè)計的組件。主要包括Connection、Command、DataReader、DataAdapter四個對象ADO.NET的結(jié)構(gòu)及組件ADO.NETDataSet是專門為獨立于任何數(shù)據(jù)源的數(shù)據(jù)訪問而設(shè)計的。因此,它可以用于多種不同的數(shù)據(jù)源,用于XML數(shù)據(jù),或用于管理應(yīng)用程序本地的數(shù)據(jù)。DataSet包含一個或多個DataTable對象的集合,這些對象由數(shù)據(jù)行和數(shù)據(jù)列以及有關(guān)DataTable對象中數(shù)據(jù)的主鍵、外鍵、約束和關(guān)系信息組成。ADO.NET的結(jié)構(gòu)及組件ADO.NET數(shù)據(jù)提供程序SQLServer.NETFramework數(shù)據(jù)提供程序(System.Data.SqlClient)OLEDB.NETFramework數(shù)據(jù)提供程序(System.Data.OleDb)ODBC.NETFramework數(shù)據(jù)提供程序(System.Data.Odbc)Oracle.NETFramework數(shù)據(jù)提供程序(System.Data.OracleClient)Connection對象Connection對象提供與數(shù)據(jù)源的連接。要存取數(shù)據(jù)源內(nèi)的數(shù)據(jù),首先要建立程序和數(shù)據(jù)源之間的連接。屬性(1)ConnectionString:獲取或設(shè)置用于打開數(shù)據(jù)庫的字符串,包括字符串的內(nèi)容和數(shù)據(jù)提供器名稱。(2)State:獲取連接的當(dāng)前狀態(tài)方法(1)Open()方法:用于打開由ConnectionString屬性指定的數(shù)據(jù)源連接(2)Close()方法:關(guān)閉數(shù)據(jù)源連接Connection對象ImportsSystemImportsSystem.DataImportsSystem.Data.SqlClient…Dimsqlconn=newsqlconnnectionSqlconn.connectionStringAsString=_"DataSource=(local);InitialCatalog=Northwind;"_&"IntegratedSecurity=true"Sqlconn.open()Command對象使用Command對象可以訪問用于返回數(shù)據(jù)、修改數(shù)據(jù)、運行存儲過程以及發(fā)送或檢索參數(shù)信息的數(shù)據(jù)庫命令。1.用構(gòu)造函數(shù)創(chuàng)建SqlCommand對象,并通過該對象的構(gòu)造函數(shù)參數(shù)來設(shè)置特定屬性值,其語法格式如下:SqlCommand命令對象名=newSqlCommand(查詢字符串,連接對象名);

SqlCommandcom=newSqlCommand(string,conn);Command對象使用Command對象可以訪問用于返回數(shù)據(jù)、修改數(shù)據(jù)、運行存儲過程以及發(fā)送或檢索參數(shù)信息的數(shù)據(jù)庫命令。Command對象的屬性

UsingconnectionAsNewSqlConnection(connectionString)DimcommandAsSqlCommand=NewSqlCommand()command.Connection=connectioncommand.CommandText="SalesByCategory"command.CommandType=CommandType.StoredProcedureCommand對象的方法ExecuteNonQuery:執(zhí)行不返回任何行的命令。典型的例子是實現(xiàn)插入、更新和刪除。ExecuteReader:通過Connection對象下達(dá)命令至數(shù)據(jù)源,將數(shù)據(jù)作為一個DataReader對象返回。用于任何返回數(shù)據(jù)的SQL查詢;ExecuteScalar:從數(shù)據(jù)庫中返回單獨值,例如與特定查詢相匹配的記錄數(shù),或者數(shù)據(jù)庫功能調(diào)用的結(jié)果。ExecuteReader代碼UsingconnectionAsNewSqlConnection(connectionString)DimcommandAsNewSqlCommand(queryString,connection)connection.Open()DimreaderAsSqlDataReader=command.ExecuteReader()DataReader對象當(dāng)Command對象返回結(jié)果集時,需要使用DataReader對象來檢索數(shù)據(jù)。DataReader對象返回一個來自Command的只讀的、只能向前的數(shù)據(jù)流。DataReader每次只能在內(nèi)存中保留一行,所以開銷非常小。在與數(shù)據(jù)庫的交互中,要獲得數(shù)據(jù)訪問的結(jié)果可用兩種方法來實現(xiàn),第一種是通過DataReader對象從數(shù)據(jù)源中獲取數(shù)據(jù)并進(jìn)行處理;第二種是通過DataSet對象將數(shù)據(jù)放置在內(nèi)存中進(jìn)行處理。UsingconnectionDimcommandAsSqlCommand=NewSqlCommand(_"SELECTCategoryID,CategoryNameFROMCategories;",_connection)connection.Open()DimreaderAsSqlDataReader=command.ExecuteReader()Ifreader.HasRowsThenDoWhilereader.Read()Console.WriteLine(reader.GetInt32(0)_&vbTab&reader.GetString(1))LoopElseConsole.WriteLine("Norowsfound.")EndIfreader.Close()EndUsingDataAdapter對象DataAdapter對象是一個雙向通道,用來把數(shù)據(jù)從數(shù)據(jù)源中讀到一個內(nèi)存表中,以及把內(nèi)存中的數(shù)據(jù)寫回到一個數(shù)據(jù)源中。這兩種操作分別稱作填充(Fill)和更新(Update)。DataAdapter對象通過Fill方法和Update方法來提供這一橋接器。DimadapterAsSqlDataAdapter=NewSqlDataAdapter(_"SELECTCategoryID,CategoryNameFROMdbo.Categories",_connection)adapter.UpdateCommand=NewSqlCommand(_"UPDATECategoriesSETCategoryName=@CategoryName"&_"WHERECategoryID=@CategoryID",connection)adapter.UpdateCommand.Parameters.Add(_"@CategoryName",SqlDbType.NVarChar,15,"CategoryName")DimparameterAsSqlParameter=_adapter.UpdateCommand.Parameters.Add(_"@CategoryID",SqlDbType.Int)parameter.SourceColumn="CategoryID"parameter.SourceVersion=DataRowVersion.OriginalDimcategoryTableAsNewDataTableadapter.Fill(categoryTable)DimcategoryRowAsDataRow=categoryTable.Rows(0)categoryRow("CategoryName")="NewBeverages"adapter.Update(categoryTable)DataAdapter執(zhí)行對數(shù)據(jù)庫的操作

1.創(chuàng)建數(shù)據(jù)庫連接對象Connection;2.創(chuàng)建Select查詢語句或Command對象;3.創(chuàng)建DataAdapter對象;4.創(chuàng)建DataSet對象;5.為DataAdapter對象自動生成更新命令;6.調(diào)用DataAdapter對象的Fill()方法填充DataSet對象;7.對DataTable中的特定記錄進(jìn)行增加、刪除、修改8.調(diào)用DataAdapter對象的Update()方法,將DataTable中的數(shù)據(jù)變化提交到數(shù)據(jù)庫。說明:當(dāng)調(diào)用Update方法時,DataAdapter將分析已做出的更改并執(zhí)行相應(yīng)的命令(Insert,Update,Delete)。DataSetDataSet相當(dāng)于內(nèi)存中的數(shù)據(jù)庫,在命名空間System.Data中定義;DataAdapter相當(dāng)于DataSet和物理數(shù)據(jù)源之間的橋梁。在DataSet內(nèi)部是一個或多個DataTable的集合,DataSet.Tables[“表名”]可獲取數(shù)據(jù)集中的一個表。在DataTable中執(zhí)行的插入、更新和刪除操作并不會自動寫回數(shù)據(jù)庫。如果想把更改寫回數(shù)據(jù)庫,則需要手動去完成,這個操作由DataAdapter.Update完成。DataSet與DataAdapterDataSet是實現(xiàn)ADO.NET斷開式連接的核心,它通過DataAdapter從數(shù)據(jù)源獲得數(shù)據(jù)后就斷開了與數(shù)據(jù)源之間的連接(這一點與前面介紹過的DataReader對象完全不同),此后應(yīng)用程序所有對數(shù)據(jù)源的操作(定義約束和關(guān)系、添加、刪除、修改、查詢、排序、統(tǒng)計等等)均轉(zhuǎn)向到DataSet,當(dāng)所有這些操作完成后可以通過DataAdapter提供的數(shù)據(jù)源更新方法將修改后的數(shù)據(jù)寫入數(shù)據(jù)庫。DataSet的組成創(chuàng)建DataSet創(chuàng)建DataSet創(chuàng)建數(shù)據(jù)集對象的語法格式為:DataSet數(shù)據(jù)集對象名=newDataSet();或:DataSet數(shù)據(jù)集對象名=newDataSet("表名");填充DataSet所謂“填充”是指使用DataAdapter對象通過執(zhí)行SQL語句從數(shù)據(jù)源得到的返回結(jié)果,使用DataAdapter對象的Fill方法傳遞給DataSet對象。其常用語法格式如下所示:Adapter.Fill(ds);或:Adapter.Fill(ds,tablename);使用DataSet添加新記錄通過DataSet向數(shù)據(jù)表添加新記錄的一般方法如下:1)建立與數(shù)據(jù)庫的連接。2)通過DataAd

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論