Проблема хранимой процедуры SQL в ASP.NET - PullRequest
1 голос
/ 27 ноября 2010

У меня есть хранимая процедура, как

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

& чтобы получить параметр состояния в моей функции, я использую функцию

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;
            }

        }
    }

Проблема в том, что я не получаю статус (выходной параметр) в моей функции,

Как я могу получить доступ к параметру состояния в моей функции, которая установлена ​​в моей хранимой процедуре.

Спасибо

Ответы [ 2 ]

5 голосов
/ 27 ноября 2010

Вам нужно получить доступ к этому выходному параметру после того, как вы вызвали свою хранимую процедуру:

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;
  }
1 голос
/ 27 ноября 2010

вы возвращаете @@status из хранимой процедуры, поэтому вы можете использовать ExecuteScalar вместо ExecuteNonQuery для возврата статуса

...