简体   繁体   English

ASP.NET中的SQL存储过程问题

[英]SQL Stored Procedure Problem in ASP.NET

I have stored procedure like 我已经存储过程像

CREATE procedure [dbo].[spAddItem]
(
  @itemId nvarchar(50),
  @itemName nvarchar(500),
  @itemDescription nvarchar(500),
  @itemImage nvarchar(100),
  @cityId  bigint,
  @Active int,
  @Status bigint output
)
as
begin tran
  declare @count as int
  declare @result as int  
  Set NOCOUNT ON

  select @count = Count(*) from Item where itemName = @itemName and itemId = @itemId

  if(@count > 0)
           begin
              set @result = -1;
           end
  else  
       begin 
                insert into Item(itemId,itemName,itemDescription,itemImage,cityId,Active)
                values (@itemId,@itemName,@itemDescription,@itemImage,@cityId,@Active) 
                set @result = 0  
        end

        if @@error=0  
          begin  
           commit tran 
           select @Status=@result
           return @Status  
          end  
         else  
          begin  
           rollback tran
           select @Status=@result
           return @Status     
          end

commit tran

& to get the status paremeter in my function i am using function &在我使用的函数中获取状态参数

public void DALInsertItem(ItemBLL it)
    {
        int rowNo;
        using (SqlConnection con = new SqlConnection(ConfigurationSettings.AppSettings["ConnectionString"]))
        {
            try
            {
                SqlParameter[] par = new SqlParameter[7];

                par[0] = new SqlParameter("@itemId",it.itemId);
                par[1] = new SqlParameter("@itemName",it.itemName);
                par[2] = new SqlParameter("@itemDescription", it.itemDescription);
                par[3] = new SqlParameter("@itemImage", it.itemImage);
                par[4] = new SqlParameter("@cityId",it.cityId);
                par[5] = new SqlParameter("@Active", it.itemActive);
                par[6] = new SqlParameter("@Status", 100);
                par[6].Direction = ParameterDirection.Output;

                rowNo = SqlHelper.ExecuteNonQuery(con, CommandType.StoredProcedure, "spAddItem", par);
            }
            catch (Exception ex)
            {
                throw ex;
            }
            finally
            {
                con.Close();
            }

            if (rowNo == -1)
            {
                it.isExistItem = false;
            }
            else
            {
                it.isExistItem = true;
            }

        }
    }

Problem is I am not getting the status(Output parameter) in my function, 问题是我没有在函数中获取状态(输出参数),

How can I access the status parameter in my function that is set in my stored procedure. 如何访问在存储过程中设置的函数中的状态参数。

Thanks 谢谢

You need to access that output parameter after you've called your stored procedure: 调用存储过程后,需要访问该输出参数:

using (SqlConnection con = new SqlConnection(ConfigurationSettings.AppSettings["ConnectionString"]))
{
   try
   {
      SqlParameter[] par = new SqlParameter[7];

      par[0] = new SqlParameter("@itemId",it.itemId);
      par[1] = new SqlParameter("@itemName",it.itemName);
      par[2] = new SqlParameter("@itemDescription", it.itemDescription);
      par[3] = new SqlParameter("@itemImage", it.itemImage);
      par[4] = new SqlParameter("@cityId",it.cityId);
      par[5] = new SqlParameter("@Active", it.itemActive);
      par[6] = new SqlParameter("@Status", 100);
      par[6].Direction = ParameterDirection.Output;

      rowNo = SqlHelper.ExecuteNonQuery(con, CommandType.StoredProcedure, "spAddItem", par);

      int returnStatus = (int)par[6].Value;
  }

您正在从存储过程中返回@@status ,因此可以使用ExecuteScalar而不是ExecuteNonQuery返回状态

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM