首 页 | 精品电影 | 音乐天堂 | 在线游戏 | Flash MTV | 三湘书屋 | 幽默笑话 | 三湘图库 | 美女写真 | IT知识库 | QQ贴图 | 加入书签

网页制作网络编程图形图象操作系统冲浪宝典软件教学网络安全认证考试通信技术电子商务业内动态书籍教程原码

最近更新 文章分类 多媒体类 精品软件

本站搜索:
您的位置:三湘时空 -> IT知识库 -> 文章分类 -> ASP.NET技巧 -> 在 ExcuteReader 中使用输出参数的问题
在 ExcuteReader 中使用输出参数的问题


文章类别:ASP.NET技巧 来源: 作者: 发表日期:2006-8-19 字体:[ ]

小游戏 | 在线影院 | 幽默笑话 | 源码下载 | Flash MTV | 音乐试听 | 书屋 | 美女写真

今天一个查询需要通过 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)

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

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

上一篇:利用相对定位及偏移量做精美输入界面 下一篇:如何解决Remoting无法传输存储过程参数的问题
本栏目热门文章
·如何实现无刷新的DropdownList联动效果 2005-10-4
·使用HttpWebRequest向网站模拟上传数据 2005-10-4
·ASP.NET中文件上传下载方法集合 2006-5-28
·当DataSet中包含主/子表时,Update更新步骤 2005-10-6
·ASP.NET2.0实现无刷新客户端回调 2005-11-13
·分享个极好的无刷新二级联动下拉列表,同样适用与firefox 2005-10-19
·在Web DataGrid中当鼠标移到某行与离开时行的颜色发生改变( 2005-10-4
·ASP.NET中实现Flash与.NET的紧密集成 2005-11-21
·关于Asp.net页面Page_Load被执行两次的问题 2005-10-4
·ASP.NET极限:页面导航 (翻译) 2005-10-8
新近更新文章
·.Net下几种日志管理方法 2006-8-23
·支持正则表达式的UrlMapping(ASP.NET2.0) 2006-8-23
·ASP.NET2.0登陆控件的使用(常见的三种方法) 2006-8-23
·ASP.NET 2.0 X64的奇怪问题 2006-8-23
·ASP.NET 2.0 - Enter Key - Default 2006-8-23
·怎样从ASP.NET 2.0中读取连接字符串的设置 2006-8-23
·一个极有可能引发ExecutionEngineException的情 2006-8-23
·用gridview显示来自excel表格里的数据 2006-8-23
·ASP.NET服务器控件PleaseWaitButton[翻译] 2006-8-23
·ASP.NET 2.0 WebService中传递DataTable 2006-8-23
首 页 | 软件发布 | 广告联系 | 下载帮助 | 意见反馈 | 网站地图
  CopyRight? 2002-2004 WWW.SXSKY.NET? All Rights Reserved
三湘时空 站长QQ:82675303 Email: