Sqlserver
 sql >> Database >  >> RDS >> Sqlserver

SQL Server:problema durante il passaggio di una variabile a una stored procedure

Non hai dichiarato un parametro, ma una variabile locale. Per dichiararlo come volevi:

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;

An per chiamarlo:

exec pOrders @enteredClientID = 'ABC123456789'

o semplicemente

exec pOrders 'ABC123456789'