成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何實現訪問多個ADO.NET結果集

開發 后端
在編程中結果集是很麻煩的事,文章這里詳細的介紹了ADO.NET結果集的處理,希望對大家有幫助。

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

  1. Dim reader As SqlDataReader  
  2. cmd.Connection.Open()  
  3. reader = cmd.ExecuteReader()  
  4. Do  
  5. ' Move through the first resultset  
  6. While reader.Read()  
  7. ' Access the row  
  8. End While  
  9. Loop While reader.NextResult()  
  10. reader.Close()  
  11. cmd.Connection.Close() 

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

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

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

  1. Dim p1 As OracleParameter  
  2. p1 = cmd.Parameters.Add("Employees", OracleType.Cursor)  
  3. p1.Direction = ParameterDirection.Output  
  4. Dim p2 As OracleParameter  
  5. p2 = cmd.Parameters.Add("Orders", OracleType.Cursor)  
  6. p2.Direction = ParameterDirection.Output 

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

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

責任編輯:田樹 來源: 博客
相關推薦

2009-11-13 10:42:09

ADO.NET Nex

2009-08-20 16:07:39

C#和ADO.NET訪

2009-11-11 15:09:35

ADO.NET數據集

2009-11-13 09:45:54

ADO.NET程序集

2009-12-21 16:53:06

ADO.NET使用說明

2009-11-13 09:53:47

ADO.NET權限集

2009-11-11 13:59:15

ADO.NET與ADO

2009-11-04 17:22:30

ADO.NET數據訪問

2009-11-13 10:01:50

ADO.NET CAS

2009-12-28 14:54:48

ADO.NET語句

2009-12-25 16:36:43

ADO.NET數據集

2009-12-30 14:59:42

ADO.NET數據集

2011-05-20 15:45:52

數據集

2009-12-23 17:54:01

ADO.NET 2.0

2009-10-29 10:10:10

ADO.NET數據集類

2009-12-29 13:57:30

訪問ADO.NET

2009-12-28 15:11:36

ADO.NET專家

2009-11-13 09:24:17

2009-12-30 15:21:55

ADO.NET訪問

2009-12-31 09:54:04

ADO.NET數據訪問
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产精品91网站 | 一区二区三区在线播放视频 | 天天精品在线 | 99精品亚洲国产精品久久不卡 | 99re6在线 | 视频一区在线播放 | 日本天天操 | 成人在线视频一区 | 国产99久久精品一区二区永久免费 | 欧美一区视频 | 午夜专区 | www.yw193.com| 1级毛片| 国产欧美精品一区二区 | 精品无码三级在线观看视频 | 国产一区二区欧美 | 中文在线播放 | 亚洲a毛片 | 日韩a | 日韩精品久久一区二区三区 | 久久久久国产成人精品亚洲午夜 | 国产一区二区在线免费观看 | 福利一区二区在线 | 亚洲第一成人影院 | 中文字幕亚洲一区 | 9色视频在线 | 国产又爽又黄的视频 | 午夜精品久久久久久久星辰影院 | 妞干网视频 | 国产7777| 91在线视频观看免费 | 国产成人精品一区二区 | 久久高清| 日韩中文字幕一区 | 九九成人 | 久久久高清 | 国产视频黄色 | 亚洲欧洲日本国产 | 欧美激情一区二区 | 亚洲精品第一国产综合野 | 国产日韩欧美精品一区二区 |