DataReader 类概述
DataReader 类对应MSSQLSERVER在 System.Data.SqlClient 命名空间中,对应的类是 SqlDataReader,主要用于读取表中的查询结果,并且是以只读方式读取的(即不能修改 DataReader 中存放的数据)。
正是由于 DataReader 类的特殊的读取方式,其访问数据的速度比较快,占用的服务器资源比较少。
SqlDataReader 类中常用的属性和方法如下表所示。
属性或方法 |
说明 |
---|---|
FieldCount |
属性,获取当前行中的列数 |
HasRows |
属性,获取 DataReader 中是否包含数据 |
IsClosed |
属性,获取 DataReader 的状态是否为已经被关闭 |
Read |
方法,让 DataReader 对象前进到下一条记录 |
Close |
方法,关闭 DataReader 对象 |
Get XXX (int i) |
方法,获取指定列的值,其中XXX代表的是数据类型。例如获取当前行第1列 double 类型的值,获取方法为GetDouble(o) |
使用 DataReader 类读取查询结果
在使用 DataReader 类读取查询结果时需要注意,当查询结果仅为一条时,可以使用 if 语句查询 DataReader 对象中的数据,如果返回值是多条数据,需要通过 while 语句遍历 DataReader 对象中的数据。
在使用 DataReader 类读取查询结果时需要通过以下步骤完成:
1) 执行 SqlCommand 对象中的 ExecuteReader 方法
具体代码如下。
SqlDataReader dr=SqlCommand 类实例 .ExecuteReader();
2) 遍历 SqlDataReader 中的结果
SqlDataReader 类中提供的 Read 方法用于判断其是否有值,并指向 SqlDataReader 结果中的下一条记录。
dr.Read()
如果返回值为 True,则可以读取该条记录,否则无法读取。
在读取记录时,要根据表中的数据类型来读取表中相应的列。
3) 关闭 SqlDataReader
dr.Close()
eg:
string sql = "SELECT * FROM UserAlertTable;";
SqlDataReader reader = null;
//这里使用Tuple元组存储下,list:得到的所有记录的集合。
List<Tuple<long, DateTime, long>> list = new List<Tuple<long, DateTime, long>>();
using (SqlConnection con = new SqlConnection(str))
{
con.Open();
SqlCommand cmd = new SqlCommand(sql,con);
reader = cmd.ExecuteReader();
while (reader.Read())
{
long id = reader["id"] == DBNull.Value ? -1 : (long)reader["id"];
DateTime datetime = reader["datetime"] == DBNull.Value ? DateTime.MinValue : (DateTime)reader["datetime"];
long number = reader["number"] == DBNull.Value ? -1 : (long)reader["number"];
Tuple<long, DateTime, long> tp = Tuple.Create<long, DateTime, long>(id, datetime, number);
list.Add(tp);
}
}
if (reader != null)
{
reader.Close();
}
ReadKey();