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

Sådan udføres lagret procedure i en anden lagret procedure i sql server

Prøv dette

Antag, at du har en gemt procedure som denne

Første lagrede procedure:

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

Nu vil du kalde denne procedure fra en anden lagret procedure som nedenfor

Anden lagret procedure

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

Som du har set ovenfor, kan vi kalde en lagret procedure fra en anden




  1. Omdøb SA-kontoen i SQL Server (T-SQL-eksempel)

  2. Hvordan håndterer jeg enkelte anførselstegn i en SQL-forespørgsel i PHP?

  3. jOOQ EXTRACT(EPOCH FRA [field]) løsning?

  4. java.sql.SQLException:Ugyldigt kolonneindeks i wildfly