訪問多個ADO.NET結(jié)果集的方法

本篇內(nèi)容介紹了“訪問多個ADO.NET結(jié)果集的方法”的有關(guān)知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細閱讀,能夠?qū)W有所成!

攀枝花網(wǎng)站建設(shè)公司創(chuàng)新互聯(lián)公司,攀枝花網(wǎng)站設(shè)計制作,有大型網(wǎng)站制作公司豐富經(jīng)驗。已為攀枝花上千家提供企業(yè)網(wǎng)站建設(shè)服務(wù)。企業(yè)網(wǎng)站搭建\外貿(mào)營銷網(wǎng)站建設(shè)要多少錢,請找那個售后服務(wù)好的攀枝花做網(wǎng)站的公司定做!

ADO.NET還是比較常用的,于是我研究了一下ADO.NET,在這里拿出來和大家分享一下,希望對大家有用。根據(jù)查詢的語法,你可以返回多個結(jié)果集。缺省情況下,data reader是位于***個結(jié)果集上的。你可以用Read方法在當(dāng)前結(jié)果集中滾動查看記錄。在找到***一個記錄時,Read方法返回false,不再繼續(xù)讀取。你應(yīng)該用NextResult方法轉(zhuǎn)移到下一個結(jié)果集。如果沒有更多的需要讀的ADO.NET結(jié)果集了,那么該方法返回false。下面的代碼說明了如何在所有返回的結(jié)果集中訪問所有的記錄:

Dim reader As SqlDataReader  cmd.Connection.Open()  reader = cmd.ExecuteReader()  Do  ' Move through the first resultset  While reader.Read()  ' Access the row  End While  Loop While reader.NextResult()  reader.Close()  cmd.Connection.Close()

當(dāng)你讀一個行的內(nèi)容時,可以通過索引或名稱來識別列。運用索引可以更快,因為提供者可以直接進入到緩沖器中。如果你指定列名,提供者就用GetOrdinal方法將名稱轉(zhuǎn)換成相應(yīng)的索引,然后執(zhí)行基于索引的訪問。注意,對于SQL Server data reader來說,所有的GetXXX方法實際上都調(diào)用了相應(yīng)的GetSqlXXX方法。對于Oracle data reader來說,情況是類似的,本地數(shù)據(jù)總是被寫進.NET Framework類型中。OracleDataReader類為它自己的內(nèi)部類型提供了一組私有的GetXXX方法。這些方法包括 GetOracleBFile、GetOracleBinary和GetOracleDateTime等。相反,OLE DB和ODBC readers只有單獨的一組get方法。

.NET Framework 1.1版通過添加方法HasRows擴展了data readers的編程接口,該方法返回一個Boolean值來說明是否有很多行需要讀。(這是ASP.NET 1.0的一個不足之處。)然而,該方法并沒有告訴我們有效的行的數(shù)量。同樣,也沒有方法或技巧使我們提前知道已經(jīng)返回了多少結(jié)果集。

在Oracle數(shù)據(jù)庫編程中,一個查詢或一個存儲過程返回的多個結(jié)果集是通過多個REF CURSOR對象處理的。有多少結(jié)果集,你就必須將多少輸出參數(shù)同命令關(guān)聯(lián)起來,以便NextResult方法可以用于Oracle數(shù)據(jù)庫。在命令文本中,一個ADO.NET結(jié)果集同一個Oracle REF CURSOR是一致的。輸出參數(shù)名必須與指針名匹配,它們的類型必須是OracleType.Cursor。例如,如果要運行的存儲過程(或命令文本)引用了兩個指針(Employees和Orders),那么下面的代碼就說明了如何進行設(shè)置以返回兩個ADO.NET結(jié)果集:

Dim p1 As OracleParameter  p1 = cmd.Parameters.Add("Employees", OracleType.Cursor)  p1.Direction = ParameterDirection.Output  Dim p2 As OracleParameter  p2 = cmd.Parameters.Add("Orders", OracleType.Cursor)  p2.Direction = ParameterDirection.Output

在上面的代碼中,cmd是一個OracleCommand對象,它指向一個命令或一個存儲過程。它執(zhí)行代碼,創(chuàng)建了兩個REF CURSOR,稱為Employees和Orders。REF CURSOR的名稱和ADO.NET輸出參數(shù)的名稱必須匹配。

ADO.NET對象模式包含兩個主要的部分——托管提供者和database-agnostic的容器類,如DataSet。托管提供者是數(shù)據(jù)源連接器的新類型;它們代替了基于COM的OLE DB提供者。到我寫這篇文章時為止,只有少數(shù)幾個托管提供者來連接商業(yè)DBMS。.NET Framework 1.1版只包含幾個本地提供者——用于SQL Server、Oracle和所有OLE DB的提供者和ODBC驅(qū)動程序。第三方的供應(yīng)商也支持MySQL并為Oracle提供了可供選擇的提供者。

“訪問多個ADO.NET結(jié)果集的方法”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實用文章!

文章題目:訪問多個ADO.NET結(jié)果集的方法
鏈接分享:http://muchs.cn/article46/pjjjeg.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供響應(yīng)式網(wǎng)站、全網(wǎng)營銷推廣定制網(wǎng)站、域名注冊、網(wǎng)頁設(shè)計公司、建站公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護公司