打印本文 打印本文 关闭窗口 关闭窗口
使用SqlParameter参数返回值时遇到的问题
作者:武汉SEO闵涛  文章来源:敏韬网  点击数927  更新时间:2007/11/14 12:53:43  文章录入:mintao  责任编辑:mintao

原来早就知道可以在调用SQL Server的存储过程,并指定参数的类型为ParameterDirection.Output来返回值,但是今天真正用起来的时候却碰到了问题,

存储过程:

CREATE procedure SqlMembership_GetAllUsers
(@ApplicationName VarChar(255),
@pagesize int,
@pageindex int,
@totalrecords int OUTPUT)
as

select @totalrecords = count(id) from SqlMembership_Users where applicationname=@applicationname

declare @indextable table(id int identity(1,1),nid int)
declare @PageLowerBound int
declare @PageUpperBound int
set @PageLowerBound=(@pageindex-1)*@pagesize
set @PageUpperBound=@PageLowerBound+@pagesize
set rowcount @PageUpperBound
insert into @indextable(nid) select id from SqlMembership_Users where applicationname=@applicationname order by id desc
select O.* from SqlMembership_Users O,@indextable t where O.id=t.nid
and t.id>@PageLowerBound and t.id<=@PageUpperBound order by t.id

调用代码:

MembershipUserCollection members = new MembershipUserCollection();
   SqlDataReader dr;
   try
   {
    SqlCommand cmd = new SqlCommand("SqlMembership_GetAllUsers",conn);
    cmd.CommandType = CommandType.StoredProcedure;

    cmd.Parameters.Add("@ApplicationName",SqlDbType.VarChar,255).Value = this.applicationName;
    cmd.Parameters.Add("@PageIndex",SqlDbType.Int).Value = pageIndex;
    cmd.Parameters.Add("@PageSize",SqlDbType.Int).Value = pageSize;
    SqlParameter parm = new SqlParameter("@totalrecords",SqlDbType.Int);
    parm.Direction = ParameterDirection.Output;
    cmd.Parameters.Add(parm);

    conn.Open();
    dr = cmd.ExecuteReader();
    while( dr.Read() )
    {     
     members.Add(MembershipUserFromReader(dr));
    }
    
    if( dr != null)
    {
     dr.Close();
    }

    totalRecords = (int) parm.Value;
   }
   catch
   {
    throw;
   }
   finally
   {
    
    conn.Close();
   }
   
   return members;

 

刚开始把红色标出的那句话放在 dr.Close之前,结果一直不能得到返回的值,最后查了一下 DataReader.Close方法才恍然大悟:

MSDN:

Close 方法将填写输出参数的值、返回值和 RecordsAffected,从而增加了关闭用于处理大型或复杂的查询的 SqlDataReader 所用的时间。如果返回值和查询影响的记录的数量不重要,则可以在调用 Close 方法前调用关联的 SqlCommand 对象的 Cancel 方法,从而减少关闭 SqlDataReader 所需的时间。

看来还是实践欠缺了一点啊

打印本文 打印本文 关闭窗口 关闭窗口