Sqlserver
 sql >> Base de Dados >  >> RDS >> Sqlserver

SQL Server - Problemas ao passar a variável para um procedimento armazenado


Você não declarou um parâmetro, mas uma variável local. Para declará-lo como você queria:
CREATE PROCEDURE pOrders (@enteredClientID varchar(20))
AS
    DECLARE @Results table (ClientID varchar(20), Num_orders int);

    SET NOCOUNT ON;

    -- Get all the order from the client
    INSERT INTO @Results
    SELECT ClientID, sum(Num_orders)
    FROM Orders O
    WHERE O.ClientID = @enteredClientID
    GROUP BY O.ClientID);

    -- Insert the orders into the results table --
    SELECT *
    FROM @Results;

GO;

Um para chamá-lo:
exec pOrders @enteredClientID = 'ABC123456789'

ou simplesmente
exec pOrders 'ABC123456789'