SqlDataReader执行带输出参数存储过程 错误分析

在上一篇随笔:SqlDataReader读取分页数据,pageCount你是肿么了?

遇到了很让人头疼的问题:SqlDataReader执行带输出参数的存储过程总是获取不到输出参数的正确值。这里将解决办法及分析过程列出,为遇到相同问题的小伙伴提供一种解决方案。

SqlDataReader读取分页数据,pageCount你是肿么了?的评论中有博友提出将 

param[2].Direction = ParameterDirection.Output;


该句代码放在执行查询前,确实有这一部分原因。按照该博友提供的方式我尝试了,但仍有问题:

复制代码
 1  param[2].Direction = ParameterDirection.Output;
 2             using (SqlDataReader reader = SQLHelper.ExecuteReader(sql, CommandType.StoredProcedure, param))
 3             {
 4 
 5                 while (reader.Read())
 6                 {
 7                     list.Add(ConvertReaderToStudentModel(reader));
 8                 }
 9             }
10             //为输出参数赋值
11             pageCount = (int)param[2].Value;
复制代码

 报错:

出现这种原因,首犯肯定是param为空了,是什么原因导致的呢?

经调试发现罪魁祸首原来在SQLHelper中

在执行前 cmd.Parameters.Clear();

执行后:

DbParameterCollention的Count为0,也就是集合中没有要加的参数了,所以出现“未将对象引用设置为对象的实例”的错误。

知道原因错在什么地方了,就知道怎么改了。将该句注释,就能得到输出参数的值了。

结果:

但网上很多SQLHelper很多都有把参数情况的,难道以后遇到这样的情况就要修改SQLHelper,肯定不行,遇到这种执行带输出参数的存储过程,还是用DataSet比较好,总之各有各的好处。

这个问题折磨了我一星期了,今天终于解决了,很开心。

突然想到一句话,分享一下:"学习不以分享为目的,就是耍流氓......";

posted @   wolfy  阅读(1421)  评论(7编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
点击右上角即可分享
微信分享提示