Синтаксическая ошибка входа в SQL Server 2005
Этот фрагмент кода (это просто повторитель, а не тот код, который я собираюсь запустить) выдает синтаксическую ошибку в команде DROP LOGIN:
declare @obso_user varchar(16)
set @obso_user = 'BEN_VA\20362781'
DROP LOGIN @obso_user
Кто-нибудь знает почему?
1 ответ
Вы не можете использовать переменную с DROP LOGIN
, Для этого вам нужно использовать динамический SQL:
DECLARE @obso_user VARCHAR(16)
SET @obso_user = 'BEN_VA\20362781'
DECLARE @sql NVARCHAR(100)
SET @sql = N'DROP LOGIN [' + @obso_user + ']'
EXEC sp_executesql @sql
Поместите это в CURSOR
сделать больше, чем один логин:
DECLARE @obso_user VARCHAR(16)
DECLARE @sql NVARCHAR(100)
DECLARE USER_CUR CURSOR FOR
SELECT [Something] FROM User_Table
OPEN USER_CUR
FETCH NEXT FROM USER_CUR INTO @obso_user
WHILE @@FETCH_STATUS = 0
BEGIN
SET @sql = N'DROP LOGIN [' + @obso_user + ']'
EXEC sp_executesql @sql
FETCH NEXT FROM USER_CUR INTO @obso_user
END
CLOSE USER_CUR
DEALLOCATE USER_CUR