SqlDataReader阅读器关闭时尝试调用 HasRows 无效

原创长白山上放羊娃 发布于2018-07-25 00:29:27 阅读数 538  收藏

在SqlHelper中封装好的SqlDataReader在调用时出现了

“阅读器关闭时尝试调用 HasRows 无效”

调试了许多次,提示的都是SqlHelper中错误

但我以为是代码出错误,但是后来才发现是因为封装的方法有问题

  1.  
    public static SqlDataReader ExecuteReader(string sql, params SqlParameter[] param)
  2.  
    {
  3.  
    //声明连接
  4.  
    using (SqlConnection Coon = new SqlConnection(SqlCoon))
  5.  
    {
  6.  
     
  7.  
    //声明命令
  8.  
    using (SqlCommand cmd = new SqlCommand(sql, Coon))
  9.  
    {
  10.  
    //打开数据库
  11.  
    if (Coon.State == ConnectionState.Closed)
  12.  
    {
  13.  
    Coon.Open();
  14.  
    }
  15.  
    //判断可变参数
  16.  
    if (param != null && param.Length > 0)
  17.  
    {
  18.  
    cmd.Parameters.AddRange(param);
  19.  
    }
  20.  
    //执行命令
  21.  
    return cmd.ExecuteReader(CommandBehavior.CloseConnection);
  22.  
    }
  23.  
    }
  24.  
    }

仔细看是因为在连接字段前加了释放空间的using

因为using作用域之后,连接自动释放,而Reader与DataSet不同,DataSet对象是一个暂存区(Cache)保留了数据库中查到的数据,而DataReader并没有将数据保存在本地内存中,这些数据是存在数据库服务器中的,连接关闭后用DataReader读取数据库就一定是读不到的。

修改后的封装方法

  1.  
    public static SqlDataReader ExecuteReader(string sql, params SqlParameter[] param)
  2.  
    {
  3.  
    //声明连接
  4.  
    SqlConnection Coon = new SqlConnection(SqlCoon);
  5.  
     
  6.  
    //声明命令
  7.  
    using(SqlCommand cmd = new SqlCommand(sql, Coon))
  8.  
    {
  9.  
    //打开数据库
  10.  
    if (Coon.State == ConnectionState.Closed)
  11.  
    {
  12.  
    Coon.Open();
  13.  
    }
  14.  
    //判断可变参数
  15.  
    if (param != null && param.Length > 0)
  16.  
    {
  17.  
    cmd.Parameters.AddRange(param);
  18.  
    }
  19.  
    //执行命令
  20.  
    return cmd.ExecuteReader(CommandBehavior.CloseConnection);
  21.  
    }
  22.  
    }

SqlDataReader阅读器关闭时尝试调用 HasRows 无效的更多相关文章

  1. 编写SqlHelper使用,在将ExecuteReader方法封装进而读取数据库中的数据时会产生Additional information: 阅读器关闭时尝试调用 Read 无效问题,解决方法与解释

    在自学杨中科老师的视频教学时,拓展编写SqlHelper使用,在将ExecuteReader方法封装进而读取数据库中的数据时 会产生Additional information: 阅读器关闭时尝试调用 ...

  2. SqlDataReader的关闭问题,报错:“阅读器关闭时尝试调用 Read 无效”

    SqlDataReader dr = cmd.ExecuteReader(CommandBehavior.CloseConnection);//关闭SqlDataReader 会自动关闭Sqlconn ...

  3. PDF阅读器关闭“使用手型工具阅读文章”功能

    1.问题描述 某些PDF文件打开时,光标显示的手型工具里面有个箭头,一点击鼠标左键,就跳转到下一页了.给阅读带来很多不便. 2.原因 因为这类PDF文档中带有"文章"(articl ...

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

    数据阅读器 当执行返回结果集的命令时,需要一个方法从结果集中提取数据. 处理结果集的方法有两个: 第一,使用数据阅读器(DataReader): 第二,同时使用数据适配器(Data Adapter)和 ...

  5. C#使用SqlDataReader读取数据库数据时CommandBehavior.CloseConnection参数的作用

    主要用在ExecuteReader(c)中,如果想要返回对象前不关闭数据库连接,须要用CommandBehavior.CloseConnection: CloseConnection解决了流读取数据模 ...

  6. 菜鸟的数据库实战-4-数据阅读器SqlDataReader

    老铁们大家好啊,我是菜鸟思奎,今天我学习的是数据库和前端的连接用到的字符串,如果有什么纰漏希望大家在评论区指正.阿里嘎多. 我的环境是Visual Studio 2008 + Microsoft SQ ...

  7. 刷新或关闭时调用onbeforeunload

    Onunload,onbeforeunload都是在刷新或关闭时调用,可以在<script>脚本中通过window.onunload来指定或者在<body>里指定.区别在于on ...

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

    遍历数据阅读器中的记录 当ExecuteReader方法返回DataReader对象时,当前光标的位置在第一条记录的前面. 必须调用阅读器的Read方法把光标移动到第一条记录,然后,第一条记录将变成当 ...

  9. 基于JSP的RSS阅读器的设计与实现

    阅读器访问地址:http://easyrss.tk/,欢迎体验! 阅读导览 一.    概述  二.    设计的基本概念和原理 三.    设计方案 四.    主要源代码 五.    阅读器使用说 ...

随机推荐

  1. JavaScript仿计算器案例源代码

    效果图 index.html <!DOCTYPE html> <html> <head> <title></title> <link ...

  2. react-native构建基本页面3---路由配置

    安装路由 运行yarn add react-native-router-flux 路由官网 路由相关配置 路由简单的DEMO // Main 才是项目的根组件 import React, { Comp ...

  3. 文件分配表(FAT)及其结构

    原链接:https://blog.csdn.net/qianjintianguo/article/details/712590?utm_source=blogxgwz6 文件分配表(FAT)是文件管理 ...

  4. 为什么SSL证书要设有效期?

    1.首先是为了安全考虑,CA机构不能保证一个网站永远是合法的,因此它需要定期检查网站. 2.其次,以往CA证书都非常贵,签发证书的机构通过设置期限来收费,是一种商业途径. 3.最后,还有最重要的原因就 ...

  5. 19新生赛 谁更nb

    题目描述: 有一堆石子共有N个.syx xxh两个人轮流拿,syx先拿.每次最少拿1颗,最多拿K颗,拿到最后1颗石子的人获 胜.syx xxh都非常聪明,拿石子的过程中不会出现失误.给出N和K,问最后 ...

  6. 【剑指Offer】39:平衡二叉树

    题目描述: 输入一棵二叉树,判断该二叉树是否是平衡二叉树 题解:递归 /*最直接的做法,遍历每个结点,借助一个获取树深度的递归函数,根据该结点的左右子树高度差判断是否平衡,然后递归地对左右子树进行判断 ...

  7. Python实现人工神经网络逼近股票价格

    1.基本数据绘制成图 数据有15天股票的开盘价格和收盘价格,可以通过比较当天开盘价格和收盘价格的大小来判断当天股票价格的涨跌情况,红色表示涨,绿色表示跌,测试代码如下: # encoding:utf- ...

  8. python package install error and little code bugs

    When you install packages using setup.py, the error: (py37) C:\Users\weda\Phd\python packages\visibi ...

  9. laravel如何向视图传递值

    1.定义路由 Route::get('demo','DemoController@demo'); 2.定义控制器(内with();方法就是定义传递的值 key=>value)=>" ...

  10. vue中什么是模块 什么是组件?

    模块: 封装好的应用程序,它只是js文件的封装. 组件: 一个完整的单位个体,可以有js可以有css和html. 作者:晋飞翔手机号(微信同步):17812718961希望本篇文章 能给正在学习 前端 ...