ASP.NETストレージプロシージャの戻り値を取得する実装コード

1444 ワード

1.まず、テーブル(UserInfo)を作成します.
メインフィールドId、uname、upass.
2.戻り値を持つストアド・プロシージャの作成
 
  
create proc proc_addUserInfo
@uname varchar(50),
@upass varchar(50),
@Returnc int output
as
begin
insert into erp_user(u_name,u_pass)values(@uname,@upass)
set @Returnc= isnull(@@identity,0)
end

ここで戻り値はレコードを追加したIdです.
バックグラウンドコード:
 
  
SqlParameter[] para = new SqlParameter[]
{
new SqlParameter("@uname","2012"),
new SqlParameter("@upass","2012")
};
string sql_para = "dbo.proc_addUserInfo";
CommandType type=CommandType.StoredProcedure;
SQLHelper sqlh = new SQLHelper();
int Id=sqlh.ExecuteNoQuery(sql_para,type,para);

SQLHelper:
 
  
public int ExecuteNoQuery(string sql,CommandType type,params SqlParameter [] values)
{
using (SqlCommand cmd = new SqlCommand(sql, Conn))
{
cmd.CommandType = type;
if (values != null)
{
cmd.Parameters.AddRange(values);
}
SqlParameter Retvar = cmd.Parameters.Add("@Returnc", SqlDbType.Int);
Retvar.Direction = ParameterDirection.Output;
int count = cmd.ExecuteNonQuery();
return (int)Retvar.Value;
}
}