SqlDataReader类

一、常用属性

名称 说明
Depth 获取一个值,用于指示当前行的嵌套深度。 
FieldCount 获取当前行中的列数。
HasRows 获取一个值,该值指示 SqlDataReader 是否有行。
IsClosed 指定的SqlDataReader 实例是否已关闭。
Item[Int32] 获取指定列(数字索引),通常在While.Read()中使用。
Item[String] 获取指定列(字符串索引), 通常在While.Read()中使用。
RecordsAffected 获取执行 T-SQL 语句所更改、插入或删除的行数。
VisibleFieldCount 获取 SqlDataReader 中未隐藏的字段的数目。

  示例:

    class Program
    {
        static void Main(string[] args)
        {
            string str = "server=.;database=JunTest;uid=sa;pwd=123;Asynchronous Processing=true";
            SqlConnection conn = new SqlConnection(str);    //创建连接
            SqlCommand cmd = conn.CreateCommand();          //创建SqlCommand对象
            cmd.CommandText = "SELECT * FROM Person";
            conn.Open();                            //打开连接

            using (SqlDataReader reader = cmd.ExecuteReader())
            {
                Console.WriteLine(reader.FieldCount);   //2  获取列数
                Console.WriteLine(reader.Depth);        //0  嵌套深度
                Console.WriteLine(reader.HasRows);      //true  是否包含行
                Console.WriteLine(reader.IsClosed);     //false SqlDataReader是否关闭
                Console.WriteLine(reader.RecordsAffected);      //-1 执行T-SQL语句所插入、修改、删除的行数
                Console.WriteLine(reader.VisibleFieldCount);    //2  未隐藏的字段数目(一共就两列)

                while (reader.Read())
                {
                    Console.WriteLine(reader["PersonName"]);
                  //Console.WriteLine(reader[1]);   通过数字索引或字符串索引访问
                }
            }

            conn.Close();                           //关闭连接
            Console.ReadKey();
        }
    }

二、常用方法

名称 说明
Read  前进到下一记录,异步版本ReadAsync。
GetString  返回指定类型的值,其他的都类似。
NextResult  当处理批处理的T-SQL语句时,跳到下一结果,异步版本NextResultAsync。
GetValue 获得该列的值,返回object类型。
GetValues 使用当前列指来填充参数中的对象数组。
Close 关闭 SqlDataReader 对象。

  示例:

    class Program
    {
        static void Main(string[] args)
        {
            string str = "server=.;database=JunTest;uid=sa;pwd=123;Asynchronous Processing=true";
            SqlConnection conn = new SqlConnection(str);    //创建连接
            SqlCommand cmd = conn.CreateCommand();          //创建SqlCommand对象
            cmd.CommandText = "SELECT * FROM Person";
            conn.Open();                            //打开连接

            using (SqlDataReader reader = cmd.ExecuteReader())
            {
                while (reader.Read())
                {
                    Console.WriteLine(reader.IsDBNull(1));      //是否是null值
                    Console.WriteLine(reader.GetString(1));     //Get什么类型就返回什么类型,这没啥好说的。
                }
                Console.WriteLine(reader.GetName(1));               //PersonName 由数字获得列名
                Console.WriteLine(reader.GetOrdinal("PersonName")); //1 由列名获取其在reader中的数字索引

                if (reader.NextResult())
                {
                    Console.WriteLine(reader.GetString(1));
                }
            }
            conn.Close();                           //关闭连接
            Console.ReadKey();
        }
    }
时间: 2024-07-28 21:16:26

SqlDataReader类的相关文章

ADO.NET之DataSet类

DataSet相当于一个小型数据库,通过它可以管理数据和关系 1.将sql代码的返回结果填充到该类中,然后从该类中读取,显示.(类似于Sqldatareader类) using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Data.SqlClient; using System.Data; nam

Ado.NET SqlDataReader详解

ado.net的数据提供程序有三个分别是SqlServer数据提供程序,OLE DB提供程序,ODBC提供程序. 本次记录的是SqlServer提供程序中的一些知识点. ①SqlDataReader必须经过SqlCommand调用DataReader来进行实例化.该类的特点是只读,访问速度快. 通过Read方法从数据源中拉取数据,每次读取时只能获取到一条记录(只读),在这期间要保持与数据库的连接,本地DataReader并不对数据进行缓存.当对大量数据进行检索的时候,速度是很不错的.其中重要的一

关于SqlDataReader使用的一点疑惑

C#中的SqlDataReader类(System.Data.SqlClient)是用来在保持打开数据库连接的状态下取数据用的 用法如下图: "保持与数据库的连接"这个特性也是SqlDataReader与SqlDataAdapter的最大区别, 思考: 既然SqlDataReader在读取数据的时候是保持对数据库的连接, 那么,如果在ExecuteReader():方法执行之后,在reader.Read()进行逐行取值的过程中, 我们改变数据库某一行的值,那么此时这个reader走到这

(转载)提高ASP.NET Web应用性能的技巧

在这篇文章中,将介绍一些提高 ASP.NET Web 应用性能的方法和技巧.众所周知,解决性能问题是一项繁琐的工作,当出现性能问题,每个人都会归咎于编写代码的开发人员. 那性能问题到底该如何解决?以下是应用系统发布前,作为 .NET 开发人员需要检查的点. 1.debug=「false」 当创建 ASP.NET Web应用程序,默认设置为「true」.开发过程中,设置为「true」是非常有用多,但在应用程序发布部署时,需将其设置为「false」. ? 1 <compilation default

ASP.NET中常用的优化性能的方法

1. 数据库访问性能优化  数据库的连接和关闭 访问数据库资源需要创建连接.打开连接和关闭连接几个操作.这些过程需要多次与数据库交换信息以通过身份验证,比较耗费服务器资源.ASP.NET中提供了连接池(Connection Pool)改善打开和关闭数据库对性能的影响.系统将用户的数据库连接放在连接池中,需要时取出,关闭时收回连接,等待下一次的连接请求. 连接池的大小是有限的,如果在连接池达到最大限度后仍要求创建连接,必然大大影响性能.因此,在建立数据库连接后只有在真正需要操作时才打开连接,使用完

访问数据库

1. 连接数据库 在做项目的时候,我们都需要通过程序来访问SQL Server  通过ADO.NET 这一技术,我们可以在程序中,向数据库提交执行SQL语句的一堆类.  本机访问直接访问“Windows验证”,但是一般项目都是单独的数据库服务器,程序在另外一台电脑上连接SQLServer,保障安全操作.  在做项目过程中不要启用sa账户,而是建立专用的账户,这是基于安全考虑. 启用sa账户的方法:进入属性页面后,可以启用sa账户和修改密码 2. 连接数据库的字符串 在C#代码中,用来连接数据库的

ADO.NET 获取SQL SERVER数据库架构信息

1.确定可用字段数目 sqlDataReader类提供了FieldCount属性,可确定查询反悔了多少个字段. 2.确定返回行的数目 sqlDataReader中没有指示可用行的属性. 3.确定字段的名称 使用sqlDataReader的GetName方法,该方法接受一个Int整数,指定字段的序号,并在一个字段中返回其名称. 4.确定字段在.NET中的数据类型 要确定用于存储在一特定字段的内容的.NET数据类型,请使用SqlDataReader的GetFieldType方法,与GetName方法

Java进击C#——语法之ADO.NET

本章简言 上一章讲到关于C#语法的基础部分.了解相关的基础部分之后我们就要去了解一下C#是什么样子访问数库的.C#把访问数据库这一部分的知识点叫作ADO.NET.即是JAVA常常讲到的JDBC这一部分的知识点了.笔者根据使用数据库方式的不同又分为有线连接和无线连接(关于有线和无线的叫法是笔者个人定义的.因为看了不同的书里面很多叫法).不管是什么样子的叫法.只要明白有线是保持连接的状态下操作数据库.而无线是连接之后复制一份副本,关闭连接,对副本进行操作之后,在连接更新数据库.笔者认为如果只是使用的

C# 访问数据库

1. 首先引用和生命system.data.sqlClient 2. 使用sqlconnect类链接,sqlcommand类执行SQL命令,最后结果返回给sqlDataReader类或者是其他类 3.SqlConnect类 在构造时传入链接库字符串,也可以定义后通过设置connectstring属性来设置. open(),close(). 4. sqlCommand类 在构造时传入SQL命令和SqlConnection类对象,也可以定义后通过CommandText和Connection属性来设置