您的位置:首页 > 博客中心 > 数据库 >

C#与数据库访问技术总结(十二)数据阅读器(DataReader)2

时间:2022-03-14 01:54

遍历数据阅读器中的记录

当ExecuteReader方法返回DataReader对象时,当前光标的位置在第一条记录的前面。

必须调用阅读器的Read方法把光标移动到第一条记录,然后,第一条记录将变成当前记录。

如果数据阅读器所包含的记录不止一条,Read方法就返回一个Boolean值true。

想要移到下一条记录,需要再次调用Read方法。重复上述过程,直到最后一条记录,那时Read方法将返回false。

经常使用while循环来遍历记录:

    while(reader.Read())

    {

          //读取数据

    }

    只要Read方法返回的值为true,就可以访问当前记录中包含的字段。

访问字段中的值

ADO.NET提供了两种方法访问记录中的字段。

第一种是Item属性,此属性返回由字段索引或字段名指定的字段值。

第二种方法是Get方法,此方法返回由字段索引指定字段的值。

DataReader类有一个索引符,可以使用常见的数组语法访问任何字段。

使用这种方法,既可以通过指定数据列的名称,也可以通过指定数据列的编号来访问特定列的值。

第一列的编号是0,第二列编号是1,依次类推。例如:

Object value1=myDataReader["学号"];

Object value1=myDataReader[0];

Item属性

每一个DataReader类都定义了一个Item属性,此属性返回一个代码字段属性的对象。

Item属性是DataReader类的索引。

需要注意的是Item属性总是基于0开始编号的:

object FieldValue=reader[FieldName];

object FieldValue=reader[FieldIndexl;

可以把包含字段名的字符串传入Item属性,也可以把指定字段索引的32位整数传递给Item属性。

例如,如果命令是SQL select查询:

Select ID, cName  from course

使用下面任意一种方法,都可以得到两个被返回字段的值:

object ID=reader ["ID"]

object cName=reader ["cName"];

或者:

object ID=reader[0];

object cName=reader [1];

另外需要注意的是,在使用数据时需要自己负责类型转换,如下所示:

int ID=(int)reader[0];

String cName=(string)reader[1];

注意:如果类型转换错误,例如将非数字类型转化为整型,将会在运行时抛出异常。

 

热门排行

今日推荐

热门手游