ExecuteReader在执行有输出参数的存储过程时拿不到输出参数

简介:

异常处理汇总-后端系列 http://www.cnblogs.com/dunitian/p/4523006.html

后期会在博客首发更新:http://dnt.dkill.net/Article/Detail/312

今天一同志问我这个问题,这个是过程还原:

调用SQLHelper的时候发现输出参数没值了???

不用sqlhelper也是没有?神马情况?

用sqldataadapter却可以?

吓死宝宝了,赶紧看看啥情况。先换种方法看看

,,,我去,可以哇!那么是不是ExecuteReader容易有啥坑的问题呢?想了想,对头,是不是返回的reader有点问题?

先关了看看~我去,有值了!不会这么容易就搞定了吧?不行,得再试试

~~的确,reader没关闭,那输出参数就没值(其实也可以理解~reader说:本大王还没读取完呢,你丫急什么,给我等着)

不能就这样算了啊,我不能总自己写吧,sqlhelper的问题还是得解决

我去,还是没有。。。。。。。这可不行,看看sqlhelper的源码怎么搞的

万恶的清除啊!再试试

居然可以了,ok,收工了?来来来,我们继续看看

SQLHelper怎么写的?

额,经常听前辈说SqlDataAdapter是个神奇的东西,果然...

 

扩:一般很少直接返回SqlDataReader对象的,

贴一个比较弱的转换(有更好的可以贴评论中的,我就先抛个砖头)

public static IEnumerable<T> SqlDataReaderToList<T>(SqlDataReader reader) where T : new()
        {
            using (reader)
            {
                if (reader.HasRows)
                {
                    IList<T> list = new List<T>();
                    while (reader.Read())
                    {
                        T t = new T();
                        PropertyInfo[] propertys = t.GetType().GetProperties();
                        foreach (PropertyInfo pi in propertys)
                        {
                            string tempName = pi.Name;
                            //设置 RowFilter
                            reader.GetSchemaTable().DefaultView.RowFilter = string.Format("ColumnName='{0}'", tempName);
                            //判断SqlDataReader是否存在某列
                            if (reader.GetSchemaTable().DefaultView.Count > 0)
                            {
                                if (!pi.CanWrite)
                                {
                                    continue;
                                }
                                var value = reader[tempName];
                                if (value != DBNull.Value)
                                {
                                    pi.SetValue(t, value, null);
                                }
                            }
                        }
                        list.Add(t);
                    }
                    return list;
                }
            }
            return null;
        }

 

 

目录
相关文章
|
4月前
|
JavaScript 前端开发 开发者
数据输出方法
【8月更文挑战第30天】
46 3
|
2月前
输出当前文件执行代码
【10月更文挑战第11天】输出当前文件执行代码。
27 4
|
7月前
|
存储 算法 Java
C++001-初识C++与C++输出语句
C++001-初识C++与C++输出语句
20.从入门到精通:参数 位置参数 关键字参数 默认参数 匿名函数 return 语句 强制位置参数
20.从入门到精通:参数 位置参数 关键字参数 默认参数 匿名函数 return 语句 强制位置参数
|
机器学习/深度学习 PyTorch 算法框架/工具
打印一个torch网络的所有参数和参数名
在这个示例中,我们首先创建了一个张量x,然后使用clone()方法创建了一个副本张量y。我们修改副本张量的第一个元素的值,并打印原始张量和副本张量的值,可以看到它们的值分别是[1, 2, 3]和[0, 2, 3]。这说明对副本张量的修改不会影响原始张量。
991 0
|
存储 SQL 关系型数据库
MySQL的存储过程——输入参数(in)、输出参数(out)、输入输出参数(inout)
MySQL的存储过程——输入参数(in)、输出参数(out)、输入输出参数(inout)
2309 0
MySQL的存储过程——输入参数(in)、输出参数(out)、输入输出参数(inout)
|
索引 Python
Python编程 封装函数 根据输入参数计算结果返回
define function,calculate the input parameters and return the result.
170 0
Python编程 封装函数 根据输入参数计算结果返回