C# 实现获取与操作DataSet结果集

0 下载量 201 浏览量 更新于2024-08-31 收藏 135KB PDF 举报
"C#如何使用DataSet来查看和操作数据库查询结果" 在.NET框架中,`DataSet` 是一个非常重要的类,它用于存储和管理来自数据库或其他数据源的数据。在这个场景中,我们讨论的是如何使用C#编程语言通过`DataSet`获取并查看数据库查询结果。以下是对给定代码和知识点的详细解释: 首先,我们创建一个`SqlConnection` 对象,它表示到SQL Server的连接。`strcon`字符串包含了连接字符串,包括服务器地址、端口、用户名、密码和数据库名。 ```csharp string strcon = "server=192.168.2.1,1433;uid=sa;pwd=123456;database=MyDB"; SqlConnection con = new SqlConnection(strcon); ``` 接着,使用`SqlDataAdapter` 对象执行SQL查询并将结果填充到`DataSet` 中。`SqlDataAdapter` 的构造函数接受一个SQL查询字符串和一个`SqlConnection`对象作为参数。`Fill` 方法将查询结果填充到指定的`DataSet`的指定表(在本例中是`tb`)。 ```csharp SqlDataAdapter DA = new SqlDataAdapter(strsql, con); DA.Fill(ds, "tb"); ``` 一旦数据填充完成,可以使用`DataSet`的属性和方法来访问查询结果。`ds.Tables` 是一个`DataTableCollection`,包含了所有由`SqlDataAdapter` 填充的表。`ds.Tables.Count` 将给出返回的表的数量。 例如,如果查询返回一个单一的`select`语句,那么`ds.Tables[0]` 就是返回的表。可以通过`Rows` 属性访问表中的行,`ds.Tables[0].Rows.Count` 表示该表中的数据行数。 ```csharp int rowCount = ds.Tables[0].Rows.Count; ``` 访问具体数据时,可以使用索引来访问每一行和每一列。例如,`ds.Tables[0].Rows[0].ItemArray[0]` 返回第一行的第一列的值。需要注意的是,由于`Rows`集合是动态的,尝试访问不存在的索引会抛出异常。因此,在访问之前必须检查`Count`属性确保存在对应的行和列。 在处理完数据后,记得关闭数据库连接以释放资源: ```csharp con.Close(); ``` 返回`ds`,这样其他部分的代码就可以进一步处理查询结果。 在实际应用中,通常使用循环结构如`for`或`while`来遍历`DataSet`中的数据。例如,以下代码片段展示了如何安全地遍历第一张表的所有行: ```csharp if (ds.Tables.Count > 0 && ds.Tables[0].Rows.Count > 0) { foreach (DataRow row in ds.Tables[0].Rows) { foreach (var item in row.ItemArray) { Console.WriteLine(item); } } } ``` `DataSet`还可以与其他数据结构相互转换,如`DataTable`、字符串、甚至是自定义对象。这些转换在处理大量数据或集成不同组件时非常有用。 总结,`DataSet` 是C#中处理数据库查询结果的强大工具,它提供了对数据的离线访问和操作能力。通过正确使用`SqlDataAdapter` 和相关属性,可以方便地查看、遍历和操作数据库返回的结果集。在访问数据时,确保进行适当的边界检查以避免越界异常,这是良好的编程实践。