私たちは本番環境に移行しています。私はaspnet_regsql
で生成したスクリプトを実行した直後にDBAがロールを持つユーザーを作成できるスクリプトを作成したいと思います。開発環境では、Membership ProviderのAPIを使用してGlobal.asax.csにユーザーとロールを追加しています。しかし、私はこのハードコーディングされたアプローチを避けたい。今私の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