在 ExcuteReader 中使用输出参数的问题

2016-02-19 17:55 3 1 收藏

下面图老师小编要跟大家分享在 ExcuteReader 中使用输出参数的问题,简单的过程中其实暗藏玄机,还是要细心学习,喜欢还请记得收藏哦!

【 tulaoshi.com - Web开发 】

  今天一个查询需要通过 ExcuteReader  返回结果集,同时又想输出参数,刚开始的时候一直得不到输出参数的值,以为存储过程出错,但是在查询分析器里面测试是正确的,而且输出参数确实已经赋值。
  更加让人百思不得其解的是,对出输出强制类型转换丢出异常之后,确又可以得到了,难道是ado.net 的bug,想象页不可能啊,这么常用的API,不可能出这种错吧,我的代码类似一下场景:

   try {
              using (SqlDataReader dr = cmd.ExecuteReader(CommandBehavior.CloseConnection)) {
                  int val = (int)cmd.Parameters[1].Value; // 现在还是空值
                  // more
              }
          }
          catch(Exception exp) {
              throw new ApplicationException("输出参数值:" + cmd.Parameters[1].Value, exp); // 现在可以得到输出值了
          }

  真是郁闷惨,足足调试跟踪一个小时

  终于还是在MSDN中找到了答案:
  当您将 Command 对象用于存储过程时,可以将 Command 对象的 CommandType 属性设置为 StoredProcedure。当 CommandType 为 StoredProcedure 时,可以使用 Command 的 Parameters 属性来访问输入及输出参数和返回值。无论调用哪一个 Execute 方法,都可以访问 Parameters 属性。但是,当调用 ExecuteReader 时,在 DataReader 关闭之前,将无法访问返回值和输出参数。

  
  ref:http://msdn2.microsoft.com/zh-CN/library/tyy0sz6b.aspx

  原来如此啊,觉得又被MS忽悠了,想来,谁叫自己学艺不经啊,而且早改查文档

  回到自己的代码环境,还是可以解释的。
  因为当catch到Expception 的时候已经跳出 using 范围了,DataReader已经自动被关闭了,自然可以得到 输出参数的值。
  当然,如果把try catch 放到 using中还是得不到的,因为还在 using范围内,DataReader并没有被关闭。

  另外,MSDN中说只有关闭DataReader才可以访问,其实不然。
  经过测试,可以总结如下:
  1。对于ExecuteReader而言,Output parm 和 returnvalue 作为一个结果集返回DataReader,并且改结果集总是在最后一个。
  2。根据1,当有结果集时,要访问输出参数和返回值,需要调用 NextResult 到输出参数和返回值对应的结果集位置
  3。根据1 ,当Execute没有返回结果集时,就可以直接访问(注意,无需调用Read())
  4。特别注意的对于返回多个结果集的,需要调用多次NextResult;如果结果集个数又是动态的,那么当nextResult()的返回值为 false就是了。
  5。即使对ExecuteReader指定了选项CommandBehavior.SingleResult(返回单个结果集,其实是返回批处理的第一个结果集),输出参数也作为一个结果集返回。
  6。关闭DataReader(Close()),会填充输出参数,因此可以访问。
  7。由于DataReader是只读向前的,因此,即使是通过在关闭DataReader之前通过NextResult方问到了输出参数,之前的结果集都无法在访问了(某些情况,可能想通过输出参数来动态控制结果集的访问)。
  8。为解决6中的问题,可以将不使用输出参数,直接将输出参数作为第一个结果返回(SELECT @parmname)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

  以上只是,自己的总结,希望没有出入,对初学者也许有帮助。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

  ref:
  http://www.bigcircleboy.net/583a194f-2c2c-4662-9036-4e2f0eb262396084313157728108.html

来源:https://www.tulaoshi.com/n/20160219/1616393.html

延伸阅读
标签: ASP
  VBScript5中增加了许多新功能,最振奋人心的当属类和正则表达式的出现。以下是本人写的一个解析html代码的类。我是 学php的,语法有不习惯的地方,请大家多包含。 <% Class HTMLParse     ' 设置 Initialize 事件。     Private Sub Class_Initialize      &nbs...
标签: Java JAVA基础
你希望在jsp中建立一个邮件发送收取工具吗?下面将介绍的就是在jsp中建立一个邮件发送收取工具。在这篇文章中你可以了解到 Java Mail API的一些要点以及如何在 JSP中使用它。本文中还包括了在 JSP中使用 Java Mail的实例。 Java Mail是 JSP应用软件中相当强大的API。 阅读这篇文章需要对 JSP、 Java Beans和 Java Mail...
标签: ASP
创建对象 在VBScript中创建对象类型(类)时,你首先要知道,这真的很容易!我在一个下午自学,只是阅读了Microsof VB Script 的参考书,但必须承认,这书不是最容易阅读的文档。 初学者需要安装VBScript 5.0引擎,可以在Microsoft's Scripting Site下载。 我们来看代码。类的定义与函数和子过程非常类似。起始行为Class ,结尾是End C...
    我们已经熟悉在 ASP 中通过调用 SQL Server 存储过程来执行数据库操作,不过大家是否知道,在桌面级数据库 Access 中,我们也能够创建并使用“存储过程”? Access + ASP 是开发轻量级 Web 应用程序的绝佳组合:简单,快速,兼容性好,但是性能通常不高。并且,用 ADODB.Connection 和 Recordset 对象来执行 SQL 语句的方式...
UDP协议基础: UDP(UserDatagramProtocol)是一种无连接协议,与TCP操作不同,计算机间并不需要建立一个连接,同时,一个UDP应用可同时作为应用的客户或服务器方。 由于UDP协议并不需要建立一个明确的连接,因此建立UDP应用要比建立TCP应用简单得多。在TCP应用中,一个Winsock控制必须明确地设置成“监听”,而其它Winsock控制则必...

经验教程

208

收藏

63
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部