Project

General

Profile

DONG BO NGUOI DUNG.txt

Luc Tran Van, 03/21/2022 02:57 PM

 
1

    
2
SET NUMERIC_ROUNDABORT OFF
3
GO
4
SET ANSI_PADDING, ANSI_WARNINGS, CONCAT_NULL_YIELDS_NULL, ARITHABORT, QUOTED_IDENTIFIER, ANSI_NULLS ON
5
GO
6
SET XACT_ABORT ON
7
GO
8
SET TRANSACTION ISOLATION LEVEL Serializable
9
GO
10
IF @@ERROR <> 0 SET NOEXEC ON
11
GO
12
BEGIN TRANSACTION
13
GO
14
DECLARE @USER_DOMAIN VARCHAR(100), @BRANCH_CODE VARCHAR(50), @ROLE VARCHAR(100), @DEP_ID VARCHAR(15), @FULLNAME NVARCHAR(500)
15
DECLARE @Role1 INT, @Role2 INT, @BRANCH_ID VARCHAR(15)
16

    
17
DECLARE CURR_USER CURSOR LOCAL FOR  
18
SELECT TOP 50 LOWER(TLNANME),TLSUBBRID,RoleName,SECUR_CODE,TLFullName FROM TL_USER_V3  WHERE TLNANME NOT IN (SELECT TLNANME FROM TL_USER)
19
OPEN CURR_USER               
20
FETCH NEXT FROM CURR_USER INTO @USER_DOMAIN,@BRANCH_CODE,@ROLE,@DEP_ID, @FULLNAME
21
WHILE @@FETCH_STATUS = 0        
22
BEGIN
23
SET  @Role1 = (SELECT TOP(1) Id FROM AbpRoles WHERE DisplayName = @ROLE)
24
SET  @BRANCH_ID = (SELECT TOP(1) BRANCH_ID FROM CM_BRANCH WHERE BRANCH_CODE =@BRANCH_CODE OR BRANCH_ID =@BRANCH_CODE)
25
IF(@BRANCH_ID IS NULL OR @BRANCH_ID ='')
26
BEGIN
27
	--ROLLBACK TRANSACTION
28
	PRINT N'Mã đơn vị: ' +@BRANCH_ID +N' không tồn tại trong hệ thống'
29
END	
30
IF(@Role1 IS NULl)
31
BEGIN
32
	--ROLLBACK TRANSACTION
33
	--PRINT N'Mã ROLE: '+ @ROLE +N' không tồn tại trong hệ thống'
34
	SET @Role1 =(SELECT TOP 1 ID FROM AbpRoles WHERE DisplayName='NVMS')
35
END	
36
IF(NOT EXISTS (SELECT * FROM TL_USER WHERE TLNANME = @USER_DOMAIN))
37
BEGIN
38
	--PRINT @USER_DOMAIN
39
	INSERT INTO [TL_USER] ([TLID],[TLNANME],[Password],[TLFullName],[TLSUBBRID],[BRANCH_NAME],[BRANCH_TYPE],[RoleName],[EMAIL],[ADDRESS],[PHONE],[AUTH_STATUS],[MARKER_ID],[AUTH_ID],[APPROVE_DT],[ISAPPROVE],[Birthday],[ISFIRSTTIME],[SECUR_CODE],[AccessFailedCount],[AuthenticationSource],[ConcurrencyStamp],[CreatorUserId],[DeleterUserId],[EmailAddress],[EmailConfirmationCode],[IsActive],[IsDeleted],[IsEmailConfirmed],[IsLockoutEnabled],[IsPhoneNumberConfirmed],[IsTwoFactorEnabled],[LastModifierUserId],[LockoutEndDateUtc],[Name],[NormalizedEmailAddress],[NormalizedUserName],[PasswordResetCode],[PhoneNumber],[ProfilePictureId],[SecurityStamp],[ShouldChangePasswordOnNextLogin],[Surname],[TenantId],[SignInToken],[SignInTokenExpireTimeUtc],[GoogleAuthenticatorKey],[SendActivationEmail],[DEP_ID],[CreationTime],[UamFullName],[UamEmployeeId],[UamCompanyCode],[UamWfDataId],[UamCompanyName],[UamJobTitle])
40
	SELECT NULL,@USER_DOMAIN,N'd41d8cd98f00b204e9800998ecf8427e',@FULLNAME,BRANCH_ID,BRANCH_NAME,BRANCH_TYPE,@ROLE,@USER_DOMAIN+'@vietcapitalbank.com.vn',N'',N'',N'A',N'tscd_hoiso',NULL,N'Jan  1 1900 12:00AM',N'1',N'Jan  1 1900 12:00AM',N'1',NULL,0,NULL,N'1360eb6c-4581-4870-aaf7-a2986428b91d',NULL,NULL,@USER_DOMAIN+'@vietcapitalbank.com.vn',NULL,1,0,1,0,1,0,810,NULL,NULL,@USER_DOMAIN+'@VIETCAPITALBANK.COM.VN',N'ABC',NULL,NULL,NULL,N'QSTE4B7VTYWRQON4JZTJST6QN4PEVVLB',1,NULL,1,NULL,NULL,NULL,0,NULL,N'Jul  4 2021 11:22AM',NULL,NULL,NULL,NULL,NULL,NULL
41
	FROM CM_BRANCH
42
	WHERE BRANCH_CODE = @BRANCH_CODE
43
	INSERT INTO [AbpUserRoles] ([CreationTime],[CreatorUserId],[RoleId],[TenantId],[UserId])
44
	SELECT N'2021-10-06 11:22:39.4900000' AS CreationTime, NULL AS CreatorUserId, @Role1 AS RoleId, 1 AS TenantId, ID AS UserId
45
	FROM TL_USER
46
	WHERE TLNANME = @USER_DOMAIN
47
	UPDATE TL_USER SET SECUR_CODE =@DEP_ID, DEP_ID =@DEP_ID WHERE TLNANME =@USER_DOMAIN
48
END
49
ELSE
50
BEGIN
51
	PRINT 'DA TON TAI'
52
	--UPDATE TL_USER SET TLSUBBRID = @BRANCH_ID, DEP_ID =@DEP_ID WHERE TLNANME = @USER_DOMAIN
53
	--UPDATE AbpUserRoles SET RoleId = @Role1 WHERE ID IN (SELECT TOP(1) A.ID FROM AbpUserRoles A LEFT JOIN TL_USER B ON A.UserId = B.ID WHERE B.TLNANME = @USER_DOMAIN)
54
END
55
UPDATE TL_USER SET  NormalizedUserName = UPPER(TLNANME)
56
FETCH NEXT FROM CURR_USER INTO @USER_DOMAIN,@BRANCH_CODE,@ROLE,@DEP_ID, @FULLNAME
57
END
58

    
59
CLOSE CURR_USER              -- Đóng Cursor
60
DEALLOCATE CURR_USER         -- Giải phóng tài nguyên
61

    
62
IF @@ERROR <> 0 SET NOEXEC ON
63
GO
64
COMMIT TRANSACTION
65
GO
66
IF @@ERROR <> 0 SET NOEXEC ON
67
GO
68
-- This statement writes to the SQL Server Log so SQL Monitor can show this deployment.
69
IF HAS_PERMS_BY_NAME(N'sys.xp_logevent', N'OBJECT', N'EXECUTE') = 1
70
BEGIN
71
    DECLARE @databaseName AS nvarchar(2048), @eventMessage AS nvarchar(2048)
72
    SET @databaseName = REPLACE(REPLACE(DB_NAME(), N'\', N'\\'), N'"', N'\"')
73
    SET @eventMessage = N'Redgate SQL Compare: { "deployment": { "description": "Redgate SQL Compare deployed to ' + @databaseName + N'", "database": "' + @databaseName + N'" }}'
74
    EXECUTE sys.xp_logevent 55000, @eventMessage
75
END
76
GO
77
DECLARE @Success AS BIT
78
SET @Success = 1
79
SET NOEXEC OFF
80
IF (@Success = 1) PRINT 'The database update succeeded'
81
ELSE BEGIN
82
	IF @@TRANCOUNT > 0 ROLLBACK TRANSACTION
83
	PRINT 'The database update failed'
84
END
85
GO