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

遍历数据阅读器中的记录

当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];

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

Get方法

除了通过索引访问数据外,DataReader类还有一组类型安全的访问方法可以用于读取指定列的值。

这些方法是以Get开头的,并且它们的名称具有自我解释性。

例如GetInt32()、GetString()等。

这些方法都带有一个整数型参数,用于指定要读取列的编号。

每一个DataReader类都定义了一组Get方法,那些方法将返回适当类型的值。

例如,GetInt32方法把返回的字段值作为32位整数。

每一个Get方法都接受字段的索引,

例如在上面的例子中,使用以下的代码可以检索ID字段和cName字段的值:

int ID=reader. Getint32 (0);

string cName=reader. GetString(1);

实例演示DataReader

在这个例子中,将读取所有的学生信息并将其显示出来。

(1)启动Visual Studio,新建一个名为DataReaderTest的WindowsApplication项目。

(2)在Forml.cs的空白处双击鼠标,进入Page—Load事件。Page_Load事件在页面加载时执行。

(3)首先在Forml.cs中添加SqlClient的命名空间:

using System. Data. SqlClient;

(4)在Page_Load事件中添加如下代码:

using System.Drawing;
using System.Text;
using System.Windows.Forms;
using System.Data.SqlClient;
namespace DataReaderTest
{
    public partial class Form1 : Form
    {
        public Form1()
        {
            InitializeComponent();
        }
        private void Form1_Load(object sender, EventArgs e)
        {
            //定义输出消息
            string message="";
            //新建连接对象
            SqlConnection conn=new SqlConnection();
            conn.ConnectionString="Data Source=(local);Initial Catalog=Student;Integrated Security=SSPI";
            //拼接命令字符串
            string selectQuery="select ID, sName,sGrade,sSex from studentInfo";
            //新建命令对象
            SqlCommand  cmd=new SqlCommand(selectQuery, conn);
            conn.Open( );
            //关闭阅读器时将自动关闭数据库连接
            SqlDataReader reader=cmd. ExecuteReader(CommandBehavior.CloseConnection);
            //循环读取信息
            while (reader.Read())
            {
                message+="学号:"+reader[0].ToString()+" ";
                message+="姓名:"+reader["sName"].ToString()+" ";
                message+="班级:"+reader.GetString(2)+ " ";
                message+="性别:"+reader.GetString(3)+" ";
                message+="\n";
            }
            //关闭数据阅读器
            //无需关闭连接,它将自动被关闭
            reader.Close();
            //测试数据连接是否已经关闭
            if(conn.State==ConnectionState.Closed)
            {
                message+="数据连接已经关闭\n";
            }
            MessageBox.Show(message);
        }
    }
}
时间: 2024-08-28 00:28:47

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

ADO.NET数据库访问技术

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

C#与数据库访问技术总结(十一)之数据阅读器(DataReader)1

数据阅读器 当执行返回结果集的命令时,需要一个方法从结果集中提取数据. 处理结果集的方法有两个: 第一,使用数据阅读器(DataReader): 第二,同时使用数据适配器(Data Adapter)和ADO.NET数据集(DataSet). 本节将学习数据阅读器的有关知识. DataReader类 在ADO.NET中由每个数据提供程序实现自己的DataReader. 数据读取器(DataReader)是从一个数据源中选择某些数据的最简单的方法,但也是功能较弱的一个方法. DataReader类没

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

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

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可以以相同的方式连接大部分数据库.它包括了应用程序

Java加密技术(十二)——*.PFX(*.p12)&个人信息交换文件

今天来点实际工作中的硬通货! 与计费系统打交道,少不了用到加密/解密实现.为了安全起见,通过非对称加密交换对称加密密钥更是不可或缺.那么需要通过什么载体传递非对称算法公钥/私钥信息?数字证书是公钥的载体,而密钥库可以包含公钥.私钥信息. JKS和 PKCS#12都是比较常用的两种密钥库格式/标准.对于前者,搞Java开发,尤其是接触过HTTPS平台的朋友,并不陌生. JKS文件(通常为*.jks或*.keystore,扩展名无关)可以通过Java原生工具--KeyTool生成:而后者 PKCS#

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

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

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