C#使用SQL DataReader访问数据的优点和实例

 更新时间:2018年10月24日 15:21:11   作者:Czhenya  
今天小编就为大家分享一篇关于C#使用SQL DataReader访问数据的优点和实例,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧

DataReader

DataReader对象提供了用顺序的,只读的方式读取Command对象获得的数据结果集,正是因为DataReader是以顺序的方式连续的读取数据,所有DataReader会以独占的方式打开数据库的连接

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

DataReader 对象的常用属性

  • FieldCount 属性 表示记录中有多少字段
  • HasRows 属性 用来表示DataReader是否包含数据
  • IsClosed 属性 表示DataReader是否关闭

DataReader对象常用方法

  • Close 方法 将DataReader对象关闭
  • GetDataTypName 方法 取得指定的字段数据形态(类型)
  • GetName 方法 取得指定的字段数据名称
  • GetOrdinal 方法 取得指定字段名称在记录中的顺序
  • GetValue 方法 取得指定字段的数据
  • GetValues 方法 取得全部字段的数据
  • Read 方法 读取下一条记录

实例 :

mytable01表中有Id,姓名(name),年龄(age),性别(gender),部门(department),几个字段,并且有几条语句

using System;
using System.Data.SqlClient;
namespace DataReaderDemo
{
  class Program
  {
    static void Main(string[] args)
    {
      string constr = "Server = .; user=name;pwd=mima;database=mysql";
      SqlConnection myCon = new SqlConnection(constr);
      try
      {
        myCon.Open();
        string sql = "select * from mytable01 ";
        SqlCommand mycom = new SqlCommand(sql, myCon);
        //声明DataReader
        SqlDataReader mydr;
        mydr = mycom.ExecuteReader();
        if (mydr.HasRows)   
        {
          Console.WriteLine("mytable01中存在数据");
        }
        else
        {
          Console.WriteLine("mytable01中不存在任何数据");
        }
        //----------------方法----------------------
        Console.WriteLine("第一列的数据类型"+mydr.GetDataTypeName(0));
        Console.WriteLine("获取对应列的名称:(第一列)"+mydr.GetName(0));
        string mystr = "age";  //直接写会报异常,需要有个转换的过程
        Console.WriteLine(mydr.GetOrdinal(mystr));
        /* 此时将上面的15行的str,换为
         *  string sql = "select * from mytable01 where id=1";
        if (mydr.Read())
        {
          Console.WriteLine("取得指定字段的数据:" + mydr.GetValue(0));
        }
         */
        /*将15行的 str更改为:
         * string sql = "select * from mytable01 where gender='男'";
        object[] myobj = new object[mydr.FieldCount];
        while(myde.Read()){
          mydr.GetValues(myobj);
          foreach (object item in myobj)
          {
            Console.Write(item + "\t");
            Console.WriteLine();
          }
         } 
        */
        //访问DataReader 对象时使用索引要比字段名称快很多
        while (mydr.Read())
        {
          Console.WriteLine(mydr[0].ToString()+",");
          Console.WriteLine(mydr[1].ToString() + ",");
          Console.WriteLine(mydr["gender"].ToString());
        }
        //----------------属性----------------------
        Console.WriteLine("表中有几个字段:"+mydr.FieldCount);
        Console.WriteLine("是否关闭:"+mydr.IsClosed);
        mydr.Close();
        Console.WriteLine("是否关闭:" + mydr.IsClosed);
      }
      catch(Exception ex)
      {
        Console.WriteLine(ex.Message.ToString());
      }
      finally
      {
        myCon.Close();
      }
      Console.Read();
    }
  }
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。如果你想了解更多相关内容请查看下面相关链接

相关文章

  • C#基础:Equals()与运算符==的区别分析

    C#基础:Equals()与运算符==的区别分析

    本篇文章是对c#中的Equals()与运算符==的区别进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C#实现炫酷启动图-动态进度条效果

    C#实现炫酷启动图-动态进度条效果

    这篇文章主要介绍了基于C#实现炫酷启动图-动态进度条 效果,本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友可以参考下
    2019-05-05
  • C#调用js库的方法示例代码

    C#调用js库的方法示例代码

    这篇文章主要介绍了C#调用js库的方法,本文结合示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-01-01
  • C#通过重写Panel改变边框颜色与宽度的方法

    C#通过重写Panel改变边框颜色与宽度的方法

    这篇文章主要介绍了C#通过重写Panel改变边框颜色与宽度的方法,涉及C#针对Panel控件的重写与属性设置技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-08-08
  • C# 抓取网页内容的方法

    C# 抓取网页内容的方法

    C# 抓取网页内容的方法,需要的朋友可以参考一下
    2013-04-04
  • unity3D实现摄像机抖动特效

    unity3D实现摄像机抖动特效

    这篇文章主要为大家详细介绍了unity3D实现摄像机抖动特效,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-01-01
  • opencvsharp瑕疵检测的实现示例

    opencvsharp瑕疵检测的实现示例

    本文主要介绍了opencvsharp瑕疵检测的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-05-05
  • c# 使用线程对串口serialPort进行收发数据(四种)

    c# 使用线程对串口serialPort进行收发数据(四种)

    本文主要介绍了c# 使用线程对串口serialPort进行收发数据,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-07-07
  • C#实现获取磁盘空间大小的方法

    C#实现获取磁盘空间大小的方法

    这篇文章主要介绍了C#实现获取磁盘空间大小的方法,分别基于System.IO.DriveInfo.GetDrives方法与ManagementClass("Win32_LogicalDisk")来实现这一功能,是非常实用的技巧,需要的朋友可以参考下
    2014-12-12
  • C#委托与事件初探

    C#委托与事件初探

    事件是委托的一种特殊形式,当发生有意义的事情时,事件处理对象通知过程。接下来通过本文给大家介绍C#委托与事件初探,感兴趣的朋友一起学习吧
    2016-02-02

最新评论