public static SqlDataReader GetReader(string safeSql) { SqlCommand cmd = new SqlCommand(safeSql, Connection); return cmd.ExecuteReader(); } public static SqlDataReader GetReader(string Sql, params SqlParameter[] values) { SqlCommand cmd = new SqlCommand(Sql, Connection); cmd.Parameters.AddRange(values); return cmd.ExecuteReader(); }返回System.Data.SqlClient.SqlDataReader,如何取其中的值
时间: 2024-03-14 16:45:13 浏览: 138
要从返回的SqlDataReader对象中获取字段值,可以使用SqlDataReader对象的`Read()`方法将指针移动到结果集中的下一行,并使用索引或字段名来读取该行的值。例如,以下代码演示了如何使用索引获取第一列的值:
```
SqlDataReader reader = GetReader("SELECT * FROM myTable");
if (reader.Read())
{
object value = reader[0];
// do something with value
}
```
如果你知道字段名,也可以使用字段名来获取值,例如:
```
SqlDataReader reader = GetReader("SELECT * FROM myTable");
if (reader.Read())
{
object value = reader["columnName"];
// do something with value
}
```
需要注意的是,在使用SqlDataReader对象之前,必须首先打开连接,并在使用完毕后关闭连接。完整的示例代码如下:
```
using (SqlConnection connection = new SqlConnection(connectionString))
{
connection.Open();
using (SqlDataReader reader = GetReader("SELECT * FROM myTable"))
{
while (reader.Read())
{
object value = reader["columnName"];
// do something with value
}
}
connection.Close();
}
```
其中,`connectionString`是连接字符串,指定了如何连接到数据库。
阅读全文