Sqlserver
 sql >> Datenbank >  >> RDS >> Sqlserver

SQL Server – Fehler beim Übergeben einer Variablen an eine gespeicherte Prozedur

Du hast keinen Parameter deklariert, sondern eine lokale Variable. So deklarieren Sie es wie gewünscht:

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 es zu nennen:

exec pOrders @enteredClientID = 'ABC123456789'

oder einfach

exec pOrders 'ABC123456789'