1
Answer

SQL SERVER STORED PROCEDURE,ASP.NET,C#.NET

Ask a question
Diptikant Sahu

Diptikant Sahu

13y
12.6k
1
Hi,

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

Answers (1)