Sqlserver
 sql >> Base de données >  >> RDS >> Sqlserver

SQL Server - Problème lors du passage d'une variable à une procédure stockée

Vous n'avez pas déclaré de paramètre, mais une variable locale. Pour le déclarer comme vous le souhaitez :

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;

Un pour l'appeler :

exec pOrders @enteredClientID = 'ABC123456789'

ou simplement

exec pOrders 'ABC123456789'