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

Comment exécuter une procédure stockée dans une autre procédure stockée dans SQL Server

Essayez ceci

Supposons que vous ayez une procédure stockée comme celle-ci

Première procédure stockée :

Create  PROCEDURE LoginId
     @UserName nvarchar(200),
     @Password nvarchar(200)
AS
BEGIN
    DECLARE  @loginID  int

    SELECT @loginID = LoginId 
    FROM UserLogin 
    WHERE UserName = @UserName AND Password = @Password

    return @loginID
END

Maintenant, vous voulez appeler cette procédure à partir d'une autre procédure stockée comme ci-dessous

Deuxième procédure stockée

Create  PROCEDURE Emprecord
         @UserName nvarchar(200),
         @Password nvarchar(200),
         @Email nvarchar(200),
         @IsAdmin bit,
         @EmpName nvarchar(200),
         @EmpLastName nvarchar(200),
         @EmpAddress nvarchar(200),
         @EmpContactNo nvarchar(150),
         @EmpCompanyName nvarchar(200)

    AS
    BEGIN
        INSERT INTO UserLogin VALUES(@UserName,@Password,@Email,@IsAdmin)

        DECLARE @EmpLoginid int

        exec @EmpLoginid= LoginId @UserName,@Password

        INSERT INTO tblEmployee VALUES(@EmpName,@EmpLastName,@EmpAddress,@EmpContactNo,@EmpCompanyName,@EmpLoginid)
    END

Comme vous l'avez vu plus haut, nous pouvons appeler une procédure stockée à partir d'une autre