C#与数据库访问技术总结(十三)之DataReader对象

DataReader对象与数据获取

DataReader对象以“基于连接”的方式来访问数据库。

也就是说,在访问数据库、执行SQL操作时,DataReader要求一直连在数据库上。

这将会给数据库的连接负载带来一定的压力,但DataReader对象的工作方式将在很大程度上减轻这种压力。(感觉这不是前后矛盾了?)

DataReader对象的常用属性

DataReader对象提供了用顺序的、只读的方式读取用Command对象获得的数据结果集。

由于DataReader只执行读操作,并且每次只在内存缓冲区里存储结果集中的一条数据,所以使用DataReader对象的效率比较高,如果要查询大量数据,同时不需要随机访问和修改数据,DataReader是优先的选择。

DataReader对象有以下常用属性。

FieldCount属性:该属性用来表示由DataReader得到的一行数据中的字段数。

HasRows属性:该属性用来表示DataReader是否包含数据。

IsClosed属性:该属性用来表示DataReader对象是否关闭。

DataReader对象的常用方法

同样,在SQL Server Data Provider里的DataReader对象叫SqlDataReader,而在OLE DB Data Provider里叫OleDbDataReader。

DataReader对象使用指针的方式来管理所连接的结果集,它的常用方法有关闭方法、读取记录集下一条记录和读取下一个记录集的方法、读取记录集中字段和记录的方法,以及判断记录集是为空的方法。

    1.Close方法

Close方法不带参数,无返回值,用来关闭DataReader对象。

由于DataReader在执行SQL命令时一直要保持同数据库的连接,所以在DataReader对象开启的状态下,该对象所对应的Connection连接对象不能用来执行其他的操作。

所以,在使用完DataReader对象时,一定要使用Close方法关闭该DataReader对象,否则不仅会影响到数据库连接的效率,更会阻止其他对象使用Connection连接对象来访问数据库。

   2.bool Read()方法

bool Read()方法会让记录指针指向本结果集中的下一条记录,返回值是true或false。

当Command的ExecuteReader方法返回DataReader对象后,须用Read方法来获得第一条记录;

当读好一条记录想获得下一下记录时,也可以用Read方法。

如果当前记录已经是最后一条,调用Read方法将返回false。

也就是说,只要该方法返回true,则可以访问当前记录所包含的字段。

    3.bool NextResult()方法

bool NextResult()方法会让记录指针指向下一个结果集。

当调用该方法获得下一个结果集后,依然要用Read方法来开始访问该结果集。

    4.Object GetValue(int i)方法

ObjectGetValue(int i)方法根据传入的列的索引值,返回当前记录行里指定列的值。

由于事先无法预知返回列的数据类型,所以该方法使用Object类型来接收返回数据。

    5.int GetValues(Object[] values)方法

int GetValues(Object[] values)方法会把当前记录行里所有的数据(一条记录)保存到一个数组里并返回。

可以使用FieldCount属性来获知记录里字段的总数,据此定义接收返回值的数组长度。

6.获得指定宇段的方法

获得指定字段的方法有GetString、GetChar、GetInt32等,这些方法都带有一个表示列索引的参数,返回均是Object类型。

用户可以根据字段的类型,通过输入列索引,分别调用上述方法,获得指定列的值。

例如,在数据库里,id的列索引是0,通过

 string id=GetString(0); 

代码可以获得id的值。

    7.返回列的数据类型和列名的方法

可以调用GetDataTypeName()方法,通过输入列索引,获得该列的类型。

这个方法的定义是:

string GetDataTypeName( int i)

可以调用GetName()方法,通过输入列索引,获得该列的名称。

这个方法的定义是:

string GetName(int i); 

综合使用上述两方法,可以获得数据表里列名和列的字段。

   8.bool IsDBNull(int i)方法:

bool IsDBNull(int i)方法的参数用来指定列的索引号,该方法用来判断指定索引号的列的值是否为空,返回Tree或False。

DataReader对象访问数据库代码示例

下面的代码将说明如何利用DataReader对象获得并访问结果集。

//连接字符串
private static string strConnect=" data source=localhost;uid=sa;pwd=aspent;database=LOGINDB"
SqlConnetion objConnection =new SqlConnection(strConnect);
SqlCommand objCommand =new SqlCommand( " ",objConnection);
// 设置查询类的SQL语句
objCommand.CommandText= " SELECT *FROM USERS ";
try
{
    //打开数据库连接
  if( objConnection.State == ConnectionState. Closed )
  {
     objConnection.Open();
  }
  //获取运行结果
  SqlDataReader result=objCommand.ExecuteReader();
  //如果DataRead对象成功获得数据,返回true,否则返回false
  If(result.Read()==true)
  {
     //输出结果集中的各个字段
     Response.Write(result["USERID"].ToString());
     Response.Write(result["NICKNAME"].ToString());
     Response.Write(result["USERROLE"].ToString());
  }
}
catch(SqlException e)
{
     Response.Write(e.Message.ToString());
}
finally
{
  //关闭数据库连接
  if(objConnection.State == ConnectionState.Open)
  {
     objConnection.Close();
  }
  //关闭DataRead对象
  if(result.IsClosed == false)
  {
     reuslt.Close();
  }
}

DataReader提供未缓冲的数据流,该数据流使过程逻辑可以有效地按顺序处理从数据源中返回的结果。

由于数据不在内存中缓存,所以在检索大量数据时,DataReader是一种适合的选择。

另外值得注意的是,DataReader在读取数据时,限制每次只能读一条,这样无疑提高了读取效率,一般适用于返回结果只有一条数据的情况。

如果返回的是多条记录,就要慎用此对象。

时间: 2024-08-19 12:55:15

C#与数据库访问技术总结(十三)之DataReader对象的相关文章

ADO.NET数据库访问技术

ADO.net:数据库访问技术程序操作的数据都是变量或对象,这些东西都存在于内存中但是有很多的数据是存在数据库中的,数据库中的数据存在于硬盘上 作用:将数据库中的数据取到内存中来,可以让程序进行操作 将内存中的数据,写入到数据库中 1.using System.Data.SqlClient; //引用命名空间 2.建立 数据库连接类 string str = "server=.;database=Data0515;user=sa;pwd=123;";//连接字符串 SqlConnect

C#-数据库访问技术 ado.net——创建 数据库连接类 与 数据库操作方法 以及简单的数据的添加、删除、修改、查看

数据库访问技术 ado.net 将数据库中的数据,提取到内存中,展示给用户看还可以将内存中的数据写入数据库中去 并不是唯一的数据库访问技术,但是它是最底层的数据库访问技术 1.创建数据库,并设置主外键关系 2.创建新的C#项目,创建 数据库连接类 与 数据库操作方法 a.引用数据库 using System.Data.SqlClient;    b.创建数据库连接类:先进行编写连接字符串,在实例化连接类 c.创建数据库操作方法(此处不是实例化类)    d.打开数据库 → 执行操作 → 关闭数据

数据库访问技术之JDBC

在了解JDBC之前呢,我们可以先对ODBC做一个回顾,以便于更好的理解JDBC.看名字也知道这两个关系不一般,他们实现了同样的功能,为应用程序连接和操作数据库提供支持.所以,我们先从ODBC开始. ODBC ODBC(Open Database Connectivity)是开放数据库互连的简称,是一种使用SQL的应用程序接口.它是一系列的规范和对数据库访问的API.那么API+SQL就可以执行对数据库的操作.它是不依赖于DBMS的,即通过ODBC可以以相同的方式连接大部分数据库.它包括了应用程序

C#与数据库访问技术总结(十八)

ADO.NET 代码综合示例 前面已经介绍过OLE DB.NET和SQL Server.NET数据提供者可以用来连接不同的数据源. 以下代码不仅综合演示了使用ADO.NET的这两种数据提供者访问数据库的一般步骤,而且说明了使用不同种类的ADO.NET组件集合访问数据库的一般步骤. 可以通过代码进一步了解这两种数据提供者访问方式的异同之处. 使用OLE DB.NET  Provider OLE DB的数据提供者可以访问Access和SQL等数据库,代码如下: //设置连接字符串 string db

ADO.NET(数据库访问技术)

[ADO.net结构]: ADO.NET用于访问和操作数据库的两个主要组件是:.NET Framework 数据提供程序和DataSet. a..NET Framework数据提供程序:是专门为数据操作设计的组件,用于处理不同的数据源,支持访问特定的数据库.执行SQL命令和检索结果. b..NET Framework数据提供程序包含4个核心对象:  Connection:(连接)建立与特定数据源的连接:   Command:(命令)对数据源执行命令:   DataReader:( 数据读取)从数

C#与数据库访问技术总结(七)综合示例

综合示例 说明:前面介绍了那么多,光说不练假把式,还是做个实例吧. 表:首先你要准备一张表,这个自己准备吧.我们以学生表为例. 1.ExecuteScalar方法 ExecuteScalar方法执行返回单个值的命令.例如,如果想获取Student数据库中表studentInfo的学生的总人数,则可以使用这个方法执行SQL查询: Select count(*) from studentInfo . (1) 建立Windows Application 应用程序 (2) 在Form1上添加一个按钮Bu

C#与数据库访问技术总结(五)之Command对象的常用方法

Command对象的常用方法 说明:上篇总结了Command对象的几个数据成员,这节总结Command对象的常用方法. 同样,在不同的数据提供者的内部,Command对象的名称是不同的,在SQL Server Data Provider里叫SqlCommand,而在OLE DB Data Provider里叫OleDbCommand. 下面将详细介绍Command类型对象的常用方法,包括构造函数.执行不带返回结果集的SQL语句方法.执行带返回结果集的SQL语句方法和使用查询结果填充DataRea

C#与数据库访问技术总结(十六)之 DataSet对象

DataSet对象 DataSet对象可以用来存储从数据库查询到的数据结果,由于它在获得数据或更新数据后立即与数据库断开,所以程序员能用此高效地访问和操作数据库. 并且,由于DataSet对象具有离线访问数据库的特性,所以它更能用来接收海量的数据信息. DataSet对象概述 DataSet是ADO.NET中用来访问数据库的对象. 由于其在访问数据库前不知道数据库里表的结构,所以在其内部,用动态XML的格式来存放数据.这种设计使DataSet能访问不同数据源的数据. DataSet对象本身不同数

C#与数据库访问技术总结(六)之Command对象创建SQl语句代码示例

Command对象创建SQl语句代码示例 说明:前面介绍了 Command 对象的方法和一些属性,回顾一下 Command对象主要用来执行SQL语句.利用Command对象,可以查询数据和修改数据. 在下面这段代码里,首先根据连接字符串创建一个SqlConnecdon连接对象,并用此对象连接数据源:然后创建一个SqlCommand对象,并用此对象的ExecuteNonQuery方法执行不带返回结果集的SQL语句. 1 //连接字符串 2 3 private static string strCo