如何實(shí)現(xiàn)訪問(wèn)多個(gè)ADO.NET結(jié)果集
ADO.NET還是比較常用的,于是我研究了一下ADO.NET,在這里拿出來(lái)和大家分享一下,希望對(duì)大家有用。根據(jù)查詢的語(yǔ)法,你可以返回多個(gè)結(jié)果集。缺省情況下,data reader是位于***個(gè)結(jié)果集上的。你可以用Read方法在當(dāng)前結(jié)果集中滾動(dòng)查看記錄。在找到***一個(gè)記錄時(shí),Read方法返回false,不再繼續(xù)讀取。你應(yīng)該用NextResult方法轉(zhuǎn)移到下一個(gè)結(jié)果集。如果沒(méi)有更多的需要讀的ADO.NET結(jié)果集了,那么該方法返回false。下面的代碼說(shuō)明了如何在所有返回的結(jié)果集中訪問(wèn)所有的記錄:
- 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()
#T#當(dāng)你讀一個(gè)行的內(nèi)容時(shí),可以通過(guò)索引或名稱來(lái)識(shí)別列。運(yùn)用索引可以更快,因?yàn)樘峁┱呖梢灾苯舆M(jìn)入到緩沖器中。如果你指定列名,提供者就用GetOrdinal方法將名稱轉(zhuǎn)換成相應(yīng)的索引,然后執(zhí)行基于索引的訪問(wèn)。注意,對(duì)于SQL Server data reader來(lái)說(shuō),所有的GetXXX方法實(shí)際上都調(diào)用了相應(yīng)的GetSqlXXX方法。對(duì)于Oracle data reader來(lái)說(shuō),情況是類似的,本地?cái)?shù)據(jù)總是被寫進(jìn).NET Framework類型中。OracleDataReader類為它自己的內(nèi)部類型提供了一組私有的GetXXX方法。這些方法包括 GetOracleBFile、GetOracleBinary和GetOracleDateTime等。相反,OLE DB和ODBC readers只有單獨(dú)的一組get方法。
.NET Framework 1.1版通過(guò)添加方法HasRows擴(kuò)展了data readers的編程接口,該方法返回一個(gè)Boolean值來(lái)說(shuō)明是否有很多行需要讀。(這是ASP.NET 1.0的一個(gè)不足之處。)然而,該方法并沒(méi)有告訴我們有效的行的數(shù)量。同樣,也沒(méi)有方法或技巧使我們提前知道已經(jīng)返回了多少結(jié)果集。
在Oracle數(shù)據(jù)庫(kù)編程中,一個(gè)查詢或一個(gè)存儲(chǔ)過(guò)程返回的多個(gè)結(jié)果集是通過(guò)多個(gè)REF CURSOR對(duì)象處理的。有多少結(jié)果集,你就必須將多少輸出參數(shù)同命令關(guān)聯(lián)起來(lái),以便NextResult方法可以用于Oracle數(shù)據(jù)庫(kù)。在命令文本中,一個(gè)ADO.NET結(jié)果集同一個(gè)Oracle REF CURSOR是一致的。輸出參數(shù)名必須與指針名匹配,它們的類型必須是OracleType.Cursor。例如,如果要運(yùn)行的存儲(chǔ)過(guò)程(或命令文本)引用了兩個(gè)指針(Employees和Orders),那么下面的代碼就說(shuō)明了如何進(jìn)行設(shè)置以返回兩個(gè)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是一個(gè)OracleCommand對(duì)象,它指向一個(gè)命令或一個(gè)存儲(chǔ)過(guò)程。它執(zhí)行代碼,創(chuàng)建了兩個(gè)REF CURSOR,稱為Employees和Orders。REF CURSOR的名稱和ADO.NET輸出參數(shù)的名稱必須匹配。
ADO.NET對(duì)象模式包含兩個(gè)主要的部分——托管提供者和database-agnostic的容器類,如DataSet。托管提供者是數(shù)據(jù)源連接器的新類型;它們代替了基于COM的OLE DB提供者。到我寫這篇文章時(shí)為止,只有少數(shù)幾個(gè)托管提供者來(lái)連接商業(yè)DBMS。.NET Framework 1.1版只包含幾個(gè)本地提供者——用于SQL Server、Oracle和所有OLE DB的提供者和ODBC驅(qū)動(dòng)程序。第三方的供應(yīng)商也支持MySQL并為Oracle提供了可供選擇的提供者。