使用 ADO.NET 的 NextResult 方法取得多个 Result Set
2011-09-06 00:06
405 查看
从 ADO.NET 1.x 开始,DataReader 就可以在单一次的查询动作中,「批次 (batch)」读取 T-SQL 语句以取回多个 table (数据表) 的数据,也就是一次能够回传多个「结果集 (Result Set)」,亦即所谓的「批次查询」。其中 DataReader 的 NextResult 方法,是用来取得批次查询中,下一个 Result Set 的结果。例如若要从两个不同的 table 中捞取 column 值,分别绑定至两个 DropDownList 中,我们不需要浪费系统资源去建立两个 DataSource 对象,而可以直接用下列的 Code-behind
代码,仅透过单一次的数据库连结来达成
读取时若还有其它的 Result Set,则 NextResult 方法会返回 True;因此我们也可透过返回的布尔值,搭配 While 或 Do Until 等循环,依序再往下读取 Result Set。根据默认,DataReader 会由第一个 Result Set 开始读取。此外,若连结的为 SQL Server 数据库,从 ADO.NET 1.x 开始,DataReader 即支持以 GetSql 开头的方法来取得数据,其「性能 (performance)」会比Get 开头的方法要好。
还有一种写法:
哈哈 !
代码,仅透过单一次的数据库连结来达成
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 开头的方法要好。
还有一种写法:
SqlConnection scConn = null; SqlCommand scCmd = null; SqlDataReader scReader = null; strSql = "SELECT * FROM Customers;" + "SELECT * FROM Orders;" + "SELECT * FROM [Order Details]"; scCmd = new SqlCommand(strSql, scConn); scReader = scCmd.ExecuteReader(); do { while (scReader.Read()) { Response.Write(scReader[0] + " - " + scReader[1] + "<br>"); } } while (scReader.NextResult());
哈哈 !
相关文章推荐
- 使用 ADO.NET 的 NextResult 方法取得多个 Result Set
- 使用 ADO.NET 的 NextResult 方法取得多个 Result Set
- 总结:ADO.NET在开发中的部分使用方法和技巧 选择自 yangyifan0 的 Blog
- Silverlight + WCF使用Linq to SQL以及ADO.NET Entity Data Model更新数据库子表方法
- 27:ASP.NET复习系列- ADO.NET基本知识点-数据集的使用方法和技巧
- Sybase ASE数据库使用ADO.net访问存储过程方法详解
- 总结:ADO.NET在开发中的部分使用方法和技巧
- Sybase ASE数据库使用ADO.net访问存储过程方法详解
- ADO.NET访问数据库-SqlCommand的ExecuteReader方法一般配合sqldatareader使用
- 用NextResult方法取得多个Result Set
- ADO.NET在开发中的部分使用方法和技巧
- 总结:ADO.NET在开发中的部分使用方法和技巧
- 使用ADO.NET类及方法实现数据库的查询并返回一个Object 数组
- 参数化使用ADO.NET的OleDb方法时注意不能使用@参数
- ADO.NET在开发中的部分使用方法和技巧 -2
- C#使用ADO.Net部件来访问Access数据库的方法
- 使用 ADO.NET 的 ExecuteScalar 方法返回单一值
- ADO.NET在开发中的部分使用方法与技巧
- ADO.NET 的最全实例,Ado.Net最佳使用方法 ADO.NET 的最佳实践技巧 (转载)
- ASP.NET#使用母版时,如果要使用js中的getElementById()方法取得某个内容页的元素时要注意的问题