使用 ADO.NET 的 NextResult 方法取得多个 Result Set
生活随笔
收集整理的這篇文章主要介紹了
使用 ADO.NET 的 NextResult 方法取得多个 Result Set
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
(本帖在版工的舊 Blog 中,發表日期為 2007/04/06)
(本帖有些 Hyperlink 是連到臺灣的網站,若無法連結,麻煩請留言反應)
從 ADO.NET 1.x 開始,DataReader 就可以在單一次的查詢動作中,「批次 (batch)」讀取 T-SQL 語句以取回多個 table (數據表) 的數據,也就是一次能夠回傳多個「結果集 (Result Set)」,亦即所謂的「批次查詢」。其中 DataReader 的 NextResult 方法,是用來取得批次查詢中,下一個 Result Set 的結果。例如若要從兩個不同的 table 中撈取 column 值,分別綁定至兩個 DropDownList 中,我們不需要浪費系統資源去建立兩個 DataSource 對象,而可以直接用下列的 Code-behind 代碼,僅透過單一次的數據庫連結來達成:
using?(SqlConnection?conn?=?new?SqlConnection(strConnString))?{
?conn.Open();
?using?(SqlCommand?cmd?=?new?SqlCommand())?{
cmd.Connection?=?conn;
// 利用分號「;」串連多句 SQL 語句,之后再一次丟進數據庫去執行,達成「批次」讀取或更新
// 數據庫的目的。此技巧亦適用于 INSERT、UPDATE、DELETE 的「批次」執行。???????
cmd.CommandText?=?"SELECT?字段1,字段2?FROM?數據表1?;?SELECT?*?FROM?數據表2";
using?(SqlDataReader?dr?=?cmd.ExecuteReader())?{
while(dr.Read())?{
this.DropDownList1.Items.Add(dr.GetSqlString(0).ToString()?+?dr.GetSqlInt32(1).ToString());
}
dr.NextResult();
while(dr.Read())?{
this.DropDownList2.Items.Add(dr.GetString(0)?+?dr.GetInt32(1));
}
}
}
}
(本帖有些 Hyperlink 是連到臺灣的網站,若無法連結,麻煩請留言反應)
從 ADO.NET 1.x 開始,DataReader 就可以在單一次的查詢動作中,「批次 (batch)」讀取 T-SQL 語句以取回多個 table (數據表) 的數據,也就是一次能夠回傳多個「結果集 (Result Set)」,亦即所謂的「批次查詢」。其中 DataReader 的 NextResult 方法,是用來取得批次查詢中,下一個 Result Set 的結果。例如若要從兩個不同的 table 中撈取 column 值,分別綁定至兩個 DropDownList 中,我們不需要浪費系統資源去建立兩個 DataSource 對象,而可以直接用下列的 Code-behind 代碼,僅透過單一次的數據庫連結來達成:
using?(SqlConnection?conn?=?new?SqlConnection(strConnString))?{
?conn.Open();
?using?(SqlCommand?cmd?=?new?SqlCommand())?{
cmd.Connection?=?conn;
// 利用分號「;」串連多句 SQL 語句,之后再一次丟進數據庫去執行,達成「批次」讀取或更新
// 數據庫的目的。此技巧亦適用于 INSERT、UPDATE、DELETE 的「批次」執行。???????
cmd.CommandText?=?"SELECT?字段1,字段2?FROM?數據表1?;?SELECT?*?FROM?數據表2";
using?(SqlDataReader?dr?=?cmd.ExecuteReader())?{
while(dr.Read())?{
this.DropDownList1.Items.Add(dr.GetSqlString(0).ToString()?+?dr.GetSqlInt32(1).ToString());
}
dr.NextResult();
while(dr.Read())?{
this.DropDownList2.Items.Add(dr.GetString(0)?+?dr.GetInt32(1));
}
}
}
}
讀取時若還有其它的 Result Set,則 NextResult 方法會返回 True;因此我們也可透過返回的布爾值,搭配 While 或 Do Until 等循環,依序再往下讀取 Result Set。根據默認,DataReader 會由第一個 Result Set 開始讀取。此外,若連結的為 SQL Server 數據庫,從 ADO.NET 1.x 開始,DataReader 即支持以 GetSql 開頭的方法來取得數據,其「性能 (performance)」會比Get 開頭的方法要好。
總結
以上是生活随笔為你收集整理的使用 ADO.NET 的 NextResult 方法取得多个 Result Set的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 梦到黑猫咬人预示着什么
- 下一篇: 梦到虫子咬手是什么意思