프로덕션 환경으로 마이그레이션하고 있습니다. DBA가 aspnet_regsql
으로 생성 한 스크립트를 실행 한 직후에 역할을 가진 사용자를 생성 할 수있는 스크립트를 작성하고 싶습니다. 개발 환경에서 Global.asax.cs에 회원 공급자의 API가있는 사용자와 역할을 추가했습니다. 그러나 나는이 하드 코드 방식을 피하고 싶다. 이제 T-SQL의 exprience 부족이 드러났습니다. 다음 스크립트를 작성했습니다.이 스크립트는 한꺼번에 실행하지 않으면 작동합니다.SQLMembershipProvider에 대해 SQL에서 사용자와 역할을 추가하는 방법은 무엇입니까?
Use MyApps_Prod;
GO
DECLARE @user_identity CHAR(40);
DECLARE @scalar_userid AS NVARCHAR(255);
DECLARE @scalar_roleid AS NVARCHAR(255);
DECLARE @app_id AS NVARCHAR(255);
SET @user_identity = N'AMERICAS\First.Last';
SET @app_id = (SELECT DISTINCT ApplicationId
FROM [dbo].[aspnet_Applications]
WHERE loweredapplicationname = 'MyApplication');
SELECT * FROM [dbo].[aspnet_Users] WHERE UserName = @user_identity
IF NOT EXISTS (SELECT * FROM [dbo].[aspnet_Users] WHERE UserName = @user_identity)
BEGIN
INSERT INTO [dbo].aspnet_Users
([ApplicationId], [UserName], [LoweredUserName], [LastActivityDate])
VALUES
(@app_id, @user_identity, LOWER(@user_identity), GETDATE());
END;
DECLARE @role_name CHAR(40);
SET @role_name = N'Communicator';
IF NOT EXISTS (SELECT * FROM [dbo].[aspnet_Roles] WHERE RoleName = @role_name)
BEGIN
INSERT INTO [dbo].[aspnet_Roles]
([ApplicationId], [RoleName], [LoweredRoleName])
VALUES
(@app_id, @role_name, LOWER(@role_name))
END;
SET @scalar_userid = (SELECT DISTINCT UserID FROM [dbo].aspnet_Users WHERE UserName = @user_identity);
SET @scalar_roleid = (SELECT DISTINCT RoleID FROM [dbo].aspnet_Roles WHERE RoleName = @role_name);
INSERT INTO [dbo].aspnet_UsersInRoles (UserID, RoleID)
VALUES (
@scalar_userid ,
@scalar_roleid
);
SET @role_name = N'AccessAdministrator';
IF NOT EXISTS (SELECT * FROM [dbo].[aspnet_Roles] WHERE RoleName = @role_name)
BEGIN
INSERT INTO [dbo].[aspnet_Roles]
([ApplicationId], [RoleName], [LoweredRoleName])
VALUES
(@app_id, @role_name, LOWER(@role_name))
END;
SET @scalar_roleid = (SELECT DISTINCT RoleID FROM [dbo].aspnet_Roles WHERE RoleName = @role_name);
INSERT INTO [dbo].aspnet_UsersInRoles (UserID, RoleID)
VALUES (
@scalar_userid ,
@scalar_roleid
);
GO
나는 내가 세미콜론으로 각 INSERT
을 종료하면 작동하도록 INSERTs
를 가져온 다음 GO
을 추가 할 수 있음을 발견했다, 그러나 나는 재 선언하고 각 변수를 재 할당해야합니다.
어떻게 실제 SQL 개발자가이 작업을 수행합니까?
모두 실패한 경우 v1의 경우 global.asax에두고 v2의 경우 제거하십시오. – Greg