打印本文 打印本文 关闭窗口 关闭窗口
ado.net获取存储过程的返回值
作者:武汉SEO闵涛  文章来源:敏韬网  点击数616  更新时间:2009/4/23 10:41:05  文章录入:mintao  责任编辑:mintao

--------------------------------------------
假设有存储过程如下:
---------------------------------------------

CREATE proc sp_uptmp @tmpName varchar(50),@srcPos varchar(255)
as

Begin TRAN
     insert into t_template values(@tmpName,@srcPos)
COMMIT 

return isnull(@@identity,0)
GO


------------------------------------------------------------
在 ado.net 里面获取返回值的方法为(c#):
------------------------------------------------------------
   SqlConnection dbconn = new SqlConnection(connStr);
   SqlCommand cmd = new SqlCommand("sp_uptmp",dbconn);
   cmd.CommandType = CommandType.StoredProcedure;

   SqlParameter tmpName = cmd.Parameters.Add("@tmpName",SqlDbType.VarChar);
   SqlParameter srcPos = _cmd.Parameters.Add("@srcPos",SqlDbType.VarChar);
   SqlParameter rtnval = cmd.Parameters.Add("rval",SqlDbType.Int);

   tmpName.Direction = ParameterDirection.Input;
   srcPos.Direction = ParameterDirection.Input;
   rtnval.Direction = ParameterDirection.ReturnValue;

   tmpName.Value = "";
   srcPos.Value = "";
   dbconn.Open();
   cmd.ExecuteNonQuery();
   dbconn.Close();

   tmpid = (int)rtnval.Value;  //此处即为返回值

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