SqlDataReader无法获取Procedure的Output参数值?

SqlDataReader无法获取Procedure的Output参数值?
| |
Post by 幻想曲 at 08 Apr 2007 11:22
<script type="text/javascript"> </script><script src="http://pagead2.googlesyndication.com/pagead/show_ads.js" type="text/javascript"> </script><script language="JavaScript1.1" src="http://pagead2.googlesyndication.com/cpa/ads?client=ca-pub-3122628043669411&cpa_choice=CAAQ9cm1_wEaCBkyusVe5rXbKOm84YcB&oe=utf-8&dt=1180689775718&lmt=1180689775&format=ref_text&output=textlink&correlator=1180689775703&url=http%3A%2F%2Fwww.lemongtree.com%2FArchives%2FDataReader_procedure.aspx&region=_google_cpa_region_&ref=http%3A%2F%2Fwww.google.cn%2Fsearch%3Fq%3Dout%2BSqlDataReader%2B%26complete%3D1%26hl%3Dzh-CN%26newwindow%3D1&cc=100&flash=6&u_h=768&u_w=1024&u_ah=738&u_aw=1024&u_cd=32&u_tz=480&u_java=true" type="text/javascript"></script> 网上冲浪更快更爽,下载带有 Google 工具栏的 Firefox
同样的参数去执行一段存储过程
返回类型为DataTable时有值,而返回SqlDataReader时却为空.
public static DataTable ExecuteDataTable(string Text, CommandType commandType, SqlParameter[] para, out int pagecount, out int recordcount)
        {
            using (SqlConnection conn = new SqlConnection(SqlConnectionString))
            {
                SqlCommand comm = conn.CreateCommand();
               
                comm.CommandText = Text;
                comm.CommandType = commandType;
                foreach (SqlParameter p in para)
                {
                    comm.Parameters.Add(p);

                }
                comm.Parameters.Add("@pagecount", SqlDbType.Int);
                comm.Parameters.Add("@RecordCount", SqlDbType.Int);
                comm.Parameters["@pagecount"].Direction = ParameterDirection.Output;
                comm.Parameters["@RecordCount"].Direction = ParameterDirection.Output;
                SqlDataAdapter da = new SqlDataAdapter(comm);
                DataSet dst = new DataSet();
                da.Fill(dst);
                if (conn.State == ConnectionState.Open)
                    conn.Close();
                pagecount = (int)comm.Parameters["@pagecount"].Value;  //这里返回正确
                recordcount = (int)comm.Parameters["@RecordCount"].Value;   //这里也正确
                return dst.Tables[0];
            }
        }
返回类型为SqlDataReader时
public static SqlDataReader ExecuteDataReader(string Text, CommandType commandType, SqlParameter[] para, out int pagecount, out int recordcount)
        {
            pagecount = 1;
            recordcount = 0;
            using (SqlConnection conn = new SqlConnection(SqlConnectionString))
            {
                SqlCommand comm = conn.CreateCommand();

                comm.CommandText = Text;
                comm.CommandType = commandType;
                foreach (SqlParameter p in para)
                {
                    comm.Parameters.Add(p);

                }
                comm.Parameters.Add("@PageCount", SqlDbType.Int);
                comm.Parameters.Add("@RecordCount", SqlDbType.Int);
                comm.Parameters["@PageCount"].Direction = ParameterDirection.Output;
                comm.Parameters["@RecordCount"].Direction = ParameterDirection.Output;
                conn.Open();
                using (SqlDataReader dr = comm.ExecuteReader())
                {
                    if (dr.Read())
                    {
                        pagecount = (int)comm.Parameters["@pagecount"].Value; //null
                        recordcount = (int)comm.Parameters["@recordcount"].Value;   //null
                    }
                    return dr;
                }
            }
        }
为什么会这样呢?

原因:

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

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

修改了一下:

 SqlDataReader dr = comm.ExecuteReader(CommandBehavior.CloseConnection);
                dr.NextResult();   //加了这一行
                pagecount = (int)comm.Parameters["@pagecount"].Value;
                recordcount = (int)comm.Parameters["@recordcount"].Value;
                
                    return dr;
                }

这样就行了 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值