use*_*394 5 sql t-sql database sql-server stored-procedures
我有以下存储过程:
ALTER PROCEDURE [dbo].[CheckAdminExists]
@SID NVARCHAR(50),
@AdminName NVARCHAR(MAX)
AS
SELECT
Administrator.ID
FROM
Administrator
WHERE
Administrator.SID = @SID
AND Administrator.Name = @AdminName
GO
Run Code Online (Sandbox Code Playgroud)
现在我想用这样的代码创建另一个SP:
IF NOT NULL (EXECUTE CheckAdminExists 'S-1','Admin')
--do something
ELSE
--do something else
Run Code Online (Sandbox Code Playgroud)
这样做的正确语法是什么?
Dar*_*ren 11
您不应该为此使用存储过程,而是使用函数来检查Admin是否存在.
然后在新的存储过程中调用CheckAdminExists函数:
CREATE FUNCTION [dbo].[CheckAdminExists] (@SID NVARCHAR(50), @AdminName NVARCHAR(MAX))
RETURNS BIT
AS
BEGIN
DECLARE @RetVal INT
SELECT @RetVal = COUNT(Administrator.ID)
FROM
Administrator
WHERE
Administrator.SID = @SID
AND Administrator.Name = @AdminName
IF @RetVal > 0
BEGIN
RETURN 1
END
RETURN 0
END
Then in your stored procedure call the function:
DECLARE @AdminExists BIT
SELECT @AdminExists = [dbo].[CheckAdminExists]
IF @AdminExists
BEGIN
-- your code
END
ELSE
BEGIN
-- your code
END
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3875 次 |
| 最近记录: |