Project

General

Profile

dbo.TL_USER_QLK_Search 1.txt

Luc Tran Van, 10/11/2024 04:28 PM

 
1

    
2
ALTER PROCEDURE dbo.TL_USER_QLK_Search
3
@p_TLID	varchar(15)  = NULL,
4
@p_TLNANME	varchar(15)  = NULL,
5
@p_Password	varchar(50)  = NULL,
6
@p_TLFullName	nvarchar(200)  = NULL,
7
@p_TLSUBBRID	varchar(15)  = NULL,
8
@p_BRANCH_LOGIN	varchar(15)  = NULL,
9
@p_BRANCH_NAME	nvarchar(200)  = NULL,
10
@p_BRANCH_TYPE	varchar(5)  = NULL,
11
@p_RoleName	varchar(20)  = NULL,
12
@p_EMAIL	varchar(50)  = NULL,
13
@p_ADDRESS	varchar(100)  = NULL,
14
@p_PHONE	varchar(15)  = NULL,
15
@p_AUTH_STATUS	varchar(1)  = NULL,
16
@p_MARKER_ID	varchar(12)  = NULL,
17
@p_AUTH_ID	varchar(12)  = NULL,
18
@p_APPROVE_DT	VARCHAR(20) = NULL,
19
@p_ISAPPROVE	varchar(1)  = NULL,
20
@p_Birthday	VARCHAR(20) = NULL,
21
@p_ISFIRSTTIME	varchar(1)  = NULL,
22
@p_SECUR_CODE	varchar(50)  = NULL,
23
@p_DEP_ID	varchar(15)  = NULL,
24
@p_TOP	INT = 10,
25
@P_LEVEL varchar(10) = NULL
26
AS
27
	--Validation is here
28
/*
29
	DECLARE @ERRORSYS NVARCHAR(15) = '' 
30
	IF ( [NOT] EXISTS ( SELECT * FROM [TABLE] WHERE  [CONDITION] ))
31
		 SET @ERRORSYS = ''
32
	IF @ERRORSYS <> '' 
33
	BEGIN
34
		SELECT ErrorCode Result, ''  CAR_ID, ErrorDesc ErrorDesc FROM SYS_ERROR WHERE ErrorCode = @ERRORSYS
35
		RETURN '0'
36
	END */
37

    
38
BEGIN -- PAGING
39

    
40
BEGIN TRANSACTION
41

    
42
-- Toannv
43
DECLARE @BRANCH_ID VARCHAR(15)
44
declare @tmp table(BRANCH_ID varchar(15))
45
declare @tmp_AUTH table(BRANCH_ID varchar(15))
46
IF(@p_SECUR_CODE IS NOT NULL AND @p_SECUR_CODE <> '')
47
BEGIN
48
	SET @BRANCH_ID =ISNULL((SELECT BRANCH_ID FROM CM_DEPARTMENT WHERE DEP_ID=@p_SECUR_CODE),'')
49
	SET @p_TLSUBBRID = @BRANCH_ID
50
END
51

    
52
insert into @tmp  SELECT BRANCH_ID  FROM [dbo].[CM_BRANCH_GETCHILDID](@p_TLSUBBRID)
53
INSERT INTO @tmp_AUTH SELECT @p_TLSUBBRID
54
---- INSERT KIÊM NHIỆM ĐƠN VỊ
55
INSERT INTO @tmp_AUTH SELECT BRANCH_ID FROM TL_SYS_ROLE_MAPPING TRM
56
							WHERE 1=1
57
							AND CONVERT(DATE,GETDATE(),103) >= TRM.EFF_DATE 
58
							AND CONVERT(DATE,GETDATE(),103) <= TRM.EXP_DATE
59
							AND TLNAME =@p_MARKER_ID
60
---- INSERT KIÊM NHIỆM ĐƠN VỊ
61
IF(@p_SECUR_CODE IS NOT NULL AND @p_SECUR_CODE <> '') SET @p_DEP_ID = @p_SECUR_CODE
62
IF(@p_DEP_ID IS NOT NULL AND @p_DEP_ID <> '') SET @p_SECUR_CODE = @p_DEP_ID
63
--IF(@p_MARKER_ID IS NULL OR @p_MARKER_ID ='')
64
--BEGIN
65
--	SET @p_MARKER_ID ='sangnm1'
66
--END
67

    
68
-----------------BAODNQ 17/11/2022 : BẢNG TẠM LƯU DEP_ID---------------------
69
DECLARE @t_DEP_ID_TMP TABLE(DEP_ID VARCHAR(15))
70
DECLARE @p_DEP_ID_TMP VARCHAR(15)
71

    
72
---------------NẾU CÓ TRUYỀN SECUR_CODE, LẤY RA NHỮNG DEP_ID THỎA ĐK:---------------
73
---------------1.PHÒNG BAN TRUYỀN VÀO, 2.PHÒNG BAN CON CỦA PHÒNG BAN TRUYỀN VÀO, 
74
---------------3.PHÒNG BAN ĐANG DC USER_LOGIN KIÊM NHIỆM GDDV, 4.PHÒNG BAN CON CỦA PHÒNG BAN DC USER_LOGIN KIÊM NHIỆM
75
IF(@p_SECUR_CODE IS NOT NULL AND @p_SECUR_CODE <> '')
76
BEGIN
77
	SET @p_DEP_ID_TMP = @p_SECUR_CODE
78

    
79
	PRINT @p_DEP_ID_TMP
80

    
81
	INSERT INTO @t_DEP_ID_TMP
82
	--------TH1 : DEP_ID TRUYỀN VÀO-----------
83
		SELECT @p_DEP_ID_TMP
84
		UNION
85
	--------TH2 : PHÒNG BAN CON CỦA DEP_ID TRUYỀN VÀO---------
86
		SELECT DEP_ID FROM CM_DEPARTMENT CD WHERE CD.FATHER_ID = @p_DEP_ID_TMP
87
		UNION
88
	--------TH3 : PHÒNG BAN ĐANG DC USER_LOGIN KIÊM NHIỆM GDDV-----------
89
		SELECT DEP_ID FROM TL_SYS_ROLE_MAPPING TSM 
90
		WHERE TSM.TLNAME = @p_MARKER_ID AND ROLE_NEW = 'GDDV'
91
			AND CONVERT(DATE,GETDATE(),103) >= TSM.EFF_DATE 
92
			AND CONVERT(DATE,GETDATE(),103) <= TSM.EXP_DATE
93
		UNION
94
	---------TH4 : PHÒNG BAN CON CỦA PHÒNG BAN ĐANG DC USER_LOGIN KIÊM NHIỆM GDDV-----------
95
		SELECT CDF.DEP_ID FROM TL_SYS_ROLE_MAPPING TSMF 
96
		INNER JOIN CM_DEPARTMENT CDF ON CDF.FATHER_ID = TSMF.DEP_ID
97
		WHERE TSMF.TLNAME = @p_MARKER_ID
98
			AND CONVERT(DATE,GETDATE(),103) >= TSMF.EFF_DATE 
99
			AND CONVERT(DATE,GETDATE(),103) <= TSMF.EXP_DATE
100
END
101
-------------------ENDBAODNQ 17/11/2022--------------------
102

    
103
IF(@p_TOP IS NULL OR @P_TOP = '' OR @P_TOP = 0)
104
-- PAGING BEGIN
105
	SELECT A.*, B.AUTH_STATUS_NAME,D.BRANCH_ID, D.BRANCH_CODE,
106
			DE.DEP_NAME,DE.DEP_CODE,
107
			dbo.FN_GET_CHINHANH(D.BRANCH_ID,'KV') KHU_VUC,
108
			dbo.FN_GET_CHINHANH(D.BRANCH_ID,'CN') CHI_NHANH, 
109
			D.BRANCH_NAME PGD, D.TAX_NO,E.POS_NAME, E.EMP_CODE,
110
			--STUFF( (select ',' + R.[Name] FOR XML PATH(''), TYPE).value('.[1]', 'nvarchar(max)'), 1, 1, '') RoleName2
111
			T.RoleName2
112
			, CMA.ACC_NUM, CMA.ACC_NAME, CMA.ACC_TYPE,
113
			D.BRANCH_NAME AS BR_NAME, D.BRANCH_CODE + '-'+ D.BRANCH_NAME AS BR_FULL_NAME,
114
		    DE.DEP_CODE +'-'+ DE.DEP_NAME AS DP_FULL_NAME,
115
			K.DVDM_ID AS KHOI_ID, K.DVDM_CODE AS KHOI_CODE, K.DVDM_NAME AS KHOI_NAME
116
	-- SELECT END
117
	FROM TL_USER A
118
		INNER JOIN CM_AUTH_STATUS B ON B.AUTH_STATUS = A.AUTH_STATUS
119
		LEFT JOIN CM_BRANCH D ON  A.TLSUBBRID = D.BRANCH_ID
120
		LEFT JOIN CM_DEPARTMENT DE ON A.DEP_ID = DE.DEP_ID
121
		--LEFT JOIN AbpUserRoles UR  ON A.ID = UR.UserId
122
		--LEFT JOIN AbpRoles R ON R.Id = UR.RoleId
123
		-- GIANT 16/09/2021
124
		LEFT JOIN CM_EMPLOYEE_LOG E ON A.TLNANME = E.USER_DOMAIN
125
		LEFT JOIN CM_ACCOUNT_PAY CMA ON A.TLNANME = CMA.REF_ID
126
		INNER JOIN
127
		(SELECT A2.ID,
128
			(SELECT stuff((SELECT ',' + CONVERT(VARCHAR(MAX),R1.[DisplayName])
129
			FROM TL_USER A1
130
				LEFT JOIN AbpUserRoles UR1  ON A1.ID = UR1.UserId
131
				LEFT JOIN AbpRoles R1 ON R1.Id = UR1.RoleId
132
			WHERE A1.ID=A2.ID AND R1.DisplayName IN ('QLK','KSV')
133
			FOR XML PATH ('')
134
			), 1, 1, '')) AS [RoleName2]
135
		FROM TL_USER A2
136
		GROUP BY A2.ID) T ON T.ID=A.ID
137
		LEFT JOIN CM_DVDM K ON DE.KHOI_ID = K.DVDM_ID AND K.IS_KHOI = '1'
138
	 WHERE 1 = 1
139
		AND (A.TLID LIKE '%' + @p_TLID + '%' OR  @p_TLID IS NULL OR @p_TLID = '')
140
		AND (A.TLNANME LIKE '%' + @p_TLNANME + '%' OR  @p_TLNANME IS NULL OR @p_TLNANME = '')
141
		AND (A.Password LIKE '%' + @p_Password + '%' OR  @p_Password IS NULL OR @p_Password = '')
142
		AND (A.TLFullName LIKE '%' + @p_TLFullName + '%' OR  @p_TLFullName IS NULL OR @p_TLFullName = '')
143
		--AND (A.TLSUBBRID LIKE '%' + @p_TLSUBBRID + '%' OR  @p_TLSUBBRID IS NULL OR @p_TLSUBBRID = '')
144
		AND (A.BRANCH_NAME LIKE '%' + @p_BRANCH_NAME + '%' OR  @p_BRANCH_NAME IS NULL OR @p_BRANCH_NAME = '')
145
		AND (A.BRANCH_TYPE LIKE '%' + @p_BRANCH_TYPE + '%' OR  @p_BRANCH_TYPE IS NULL OR @p_BRANCH_TYPE = '')
146
    AND (A.TLSUBBRID = @p_BRANCH_LOGIN OR @p_BRANCH_LOGIN IS NULL OR @p_BRANCH_LOGIN = '')
147
		--AND (
148
		--	(A.DEP_ID LIKE '%' + @p_DEP_ID + '%'
149
		--		--OR (SELECT TOP 1 TRM.DEP_ID FROM TL_SYS_ROLE_MAPPING TRM 
150
		--		--	WHERE TRM.TLNAME = A.TLNANME 
151
		--		--	AND GETDATE() >= TRM.EFF_DATE AND GETDATE() <= TRM.EXP_DATE
152
		--		--	) LIKE '%' + @p_DEP_ID + '%'
153
		--		----------BAODNQ 30/9/2022 : Thêm xử lý tìm kiếm ủy quyền kiêm nhiệm--------
154
		--		OR EXISTS(SELECT * FROM TL_SYS_ROLE_MAPPING TRM 
155
		--					WHERE TRM.TLNAME = A.TLNANME 
156
		--					AND CONVERT(DATE,GETDATE(),103) >= TRM.EFF_DATE 
157
		--					AND CONVERT(DATE,GETDATE(),103) <= TRM.EXP_DATE
158
		--					AND TRM.DEP_ID = @p_DEP_ID
159
		--			)
160
		--		OR A.DEP_ID IN (SELECT DEP_ID FROM TL_SYS_ROLE_MAPPING TRM WHERE 1=1
161
		--					AND CONVERT(DATE,GETDATE(),103) >= TRM.EFF_DATE 
162
		--					AND CONVERT(DATE,GETDATE(),103) <= TRM.EXP_DATE
163
		--					AND TRM.TLNAME = @p_MARKER_ID)
164
		--		OR (@p_TLSUBBRID <> 'DV0001' AND A.TLSUBBRID =@p_TLSUBBRID)
165
		--		OR (@BRANCH_ID <> 'DV0001' AND A.TLSUBBRID =@BRANCH_ID)
166
		--	)
167
		--	OR (@p_DEP_ID IS NULL OR @p_DEP_ID = '' OR @p_SECUR_CODE IS NULL OR @p_SECUR_CODE ='')
168
		--	OR (A.SECUR_CODE IN (SELECT DEP_ID FROM CM_DEPARTMENT WHERE FATHER_ID =@p_SECUR_CODE))
169
		--	OR (A.SECUR_CODE IN (SELECT DEP_ID FROM CM_DEPARTMENT WHERE FATHER_ID =@p_DEP_ID))
170
		--)
171
		--------------BAODNQ 17/11/2022 : CHỈNH SỬA LẠI ĐIỀU KIỆN TÌM KIẾM THEO DEP_ID-------------------
172
		AND(
173
			(A.DEP_ID IN (SELECT DEP_ID FROM @t_DEP_ID_TMP)
174
				OR EXISTS(SELECT * FROM TL_SYS_ROLE_MAPPING TRM 
175
							WHERE TRM.TLNAME = A.TLNANME 
176
							AND CONVERT(DATE,GETDATE(),103) >= TRM.EFF_DATE 
177
							AND CONVERT(DATE,GETDATE(),103) <= TRM.EXP_DATE
178
							AND TRM.DEP_ID  IN (SELECT DEP_ID FROM @t_DEP_ID_TMP)
179
					)
180
			)
181
			OR (@p_DEP_ID IS NULL OR @p_DEP_ID = '')
182
		)
183
		-------------ENDBAODNQ----------------------
184
		AND (A.EMAIL LIKE '%' + @p_EMAIL + '%' OR  @p_EMAIL IS NULL OR @p_EMAIL = '')
185
		AND (A.ADDRESS LIKE '%' + @p_ADDRESS + '%' OR  @p_ADDRESS IS NULL OR @p_ADDRESS = '')
186
		AND (A.PHONE LIKE '%' + @p_PHONE + '%' OR  @p_PHONE IS NULL OR @p_PHONE = '')
187
		AND (A.AUTH_STATUS LIKE '%' + @p_AUTH_STATUS + '%' OR  @p_AUTH_STATUS IS NULL OR @p_AUTH_STATUS = '')
188
		--AND (A.MARKER_ID LIKE '%' + @p_MARKER_ID + '%' OR  @p_MARKER_ID IS NULL OR @p_MARKER_ID = '')
189
		AND (A.AUTH_ID LIKE '%' + @p_AUTH_ID + '%' OR  @p_AUTH_ID IS NULL OR @p_AUTH_ID = '')
190
		AND (DATEDIFF(DAY,A.APPROVE_DT ,CONVERT(DATETIME, @p_APPROVE_DT, 103)) = 0 OR  @p_APPROVE_DT IS NULL OR @p_APPROVE_DT = '')
191
		AND (A.ISAPPROVE LIKE '%' + @p_ISAPPROVE + '%' OR  @p_ISAPPROVE IS NULL OR @p_ISAPPROVE = '')
192
		AND (DATEDIFF(DAY,A.Birthday ,CONVERT(DATETIME, @p_Birthday, 103)) = 0 OR  @p_Birthday IS NULL OR @p_Birthday = '')
193
		AND (A.ISFIRSTTIME LIKE '%' + @p_ISFIRSTTIME + '%' OR  @p_ISFIRSTTIME IS NULL OR @p_ISFIRSTTIME = '')
194
--		AND (A.RoleName <> 'DISABLE' OR A.RoleName IS NULL)
195
    AND T.RoleName2 <> 'DISABLE' -- NGUYENTD 22042024_SECRETKEY: CHECK ROLE Ở BẢNG ROLE THAY VÌ BẢNG TL_USER
196
		--AND (
197
		--	(A.SECUR_CODE LIKE '%' + @p_SECUR_CODE + '%'
198
		--		--OR (SELECT TOP 1 TRM.DEP_ID FROM TL_SYS_ROLE_MAPPING TRM 
199
		--		--	WHERE TRM.TLNAME = A.TLNANME 
200
		--		--	AND GETDATE() >= TRM.EFF_DATE AND GETDATE() <= TRM.EXP_DATE
201
		--		--	) LIKE '%' + @p_SECUR_CODE + '%'
202
		--		----------BAODNQ 30/9/2022 : Thêm xử lý tìm kiếm ủy quyền kiêm nhiệm--------
203
		--		OR EXISTS(SELECT * FROM TL_SYS_ROLE_MAPPING TRM 
204
		--					WHERE TRM.TLNAME = A.TLNANME 
205
		--					AND CONVERT(DATE,GETDATE(),103) >= TRM.EFF_DATE 
206
		--					AND CONVERT(DATE,GETDATE(),103) <= TRM.EXP_DATE
207
		--					AND TRM.DEP_ID = @p_SECUR_CODE
208
		--			)
209
		--		OR (@p_TLSUBBRID <> 'DV0001' AND A.TLSUBBRID =@p_TLSUBBRID)
210
		--		OR (@BRANCH_ID <> 'DV0001' AND A.TLSUBBRID =@BRANCH_ID)
211
		--	) 
212
		--	OR (@p_DEP_ID IS NULL OR @p_DEP_ID = '' OR @p_SECUR_CODE IS NULL OR @p_SECUR_CODE ='')
213
		--	OR (A.SECUR_CODE IN (SELECT DEP_ID FROM CM_DEPARTMENT WHERE FATHER_ID =@p_SECUR_CODE))
214
		--	OR (A.SECUR_CODE IN (SELECT DEP_ID FROM CM_DEPARTMENT WHERE FATHER_ID =@p_DEP_ID))
215
		--)
216
		--------------BAODNQ 17/11/2022 : CHỈNH SỬA LẠI ĐIỀU KIỆN TÌM KIẾM THEO SECUR_CODE-------------------
217
		AND(
218
			(A.SECUR_CODE IN (SELECT DEP_ID FROM @t_DEP_ID_TMP)
219
				OR EXISTS(SELECT * FROM TL_SYS_ROLE_MAPPING TRM 
220
							WHERE TRM.TLNAME = A.TLNANME 
221
							AND CONVERT(DATE,GETDATE(),103) >= TRM.EFF_DATE 
222
							AND CONVERT(DATE,GETDATE(),103) <= TRM.EXP_DATE
223
							AND TRM.DEP_ID  IN (SELECT DEP_ID FROM @t_DEP_ID_TMP)
224
					)
225
			)
226
			OR (@p_SECUR_CODE IS NULL OR @p_SECUR_CODE = '')
227
		)
228
		--------------ENDBAODNQ-------------------
229
		AND (A.TLNANME != 'admin')
230
		--AND (A.TLSUBBRID IN (SELECT BRANCH_ID FROM  CM_BRANCH_GETCHILDID(@p_TLSUBBRID)))
231
		--AND ((@P_LEVEL = 'ALL' AND A.TLSUBBRID IN (SELECT BRANCH_ID from @tmp)
232
		--OR (@P_LEVEL = 'UNIT' AND A.TLSUBBRID = @p_TLSUBBRID)) OR @p_TLSUBBRID = '' OR @p_TLSUBBRID IS NULL
233

    
234
		--)
235
		AND(
236
			(@P_LEVEL = 'ALL'
237
				AND (A.TLSUBBRID IN (SELECT BRANCH_ID from @tmp)
238
					--OR (SELECT TOP 1 TRM.BRANCH_ID
239
					--		FROM TL_SYS_ROLE_MAPPING TRM
240
					--		WHERE TRM.TLNAME = A.TLNANME
241
					--		AND GETDATE() >= TRM.EFF_DATE AND GETDATE() <= TRM.EXP_DATE
242
					--	) IN (SELECT BRANCH_ID from @tmp)
243
					----------BAODNQ 30/9/2022 : Thêm xử lý tìm kiếm ủy quyền kiêm nhiệm--------
244
					OR EXISTS(SELECT *
245
							FROM TL_SYS_ROLE_MAPPING TRM
246
							WHERE 1=1
247
							AND CONVERT(DATE,GETDATE(),103) >= TRM.EFF_DATE 
248
							AND CONVERT(DATE,GETDATE(),103) <= TRM.EXP_DATE
249
							AND TRM.BRANCH_ID IN (SELECT BRANCH_ID from @tmp)
250
						)
251
					OR (@BRANCH_ID <> 'DV0001' AND A.TLSUBBRID =@BRANCH_ID)
252
					)
253
			)
254
			OR(@P_LEVEL = 'UNIT'
255
				AND (A.TLSUBBRID = @p_TLSUBBRID OR A.TLSUBBRID IN (SELECT * FROM @tmp_AUTH)
256
					--OR (SELECT TOP 1 TRM.BRANCH_ID
257
					--		FROM TL_SYS_ROLE_MAPPING TRM
258
					--		WHERE TRM.TLNAME = A.TLNANME
259
					--		AND GETDATE() >= TRM.EFF_DATE AND GETDATE() <= TRM.EXP_DATE
260
					--	) = @p_TLSUBBRID
261
					----------BAODNQ 30/9/2022 : Thêm xử lý tìm kiếm ủy quyền kiêm nhiệm--------
262
					OR EXISTS(SELECT *
263
							FROM TL_SYS_ROLE_MAPPING TRM
264
							WHERE TRM.TLNAME = A.TLNANME
265
							AND CONVERT(DATE,GETDATE(),103) >= TRM.EFF_DATE 
266
							AND CONVERT(DATE,GETDATE(),103) <= TRM.EXP_DATE
267
							AND TRM.BRANCH_ID = @p_TLSUBBRID
268
						)
269
						OR A.DEP_ID IN (SELECT DEP_ID FROM TL_SYS_ROLE_MAPPING TRM 
270
							WHERE 1=1
271
							AND CONVERT(DATE,GETDATE(),103) >= TRM.EFF_DATE 
272
							AND CONVERT(DATE,GETDATE(),103) <= TRM.EXP_DATE
273
							AND TRM.TLNAME = @p_MARKER_ID)
274
						OR (@BRANCH_ID <> 'DV0001' AND A.TLSUBBRID =@BRANCH_ID)
275
					)
276
			)
277
			--OR @BRANCH_ID = '' OR @BRANCH_ID IS NULL
278
			OR(@p_TLSUBBRID IS NULL OR @p_TLSUBBRID = '')
279
			--OR (A.SECUR_CODE IN (SELECT DEP_ID FROM CM_DEPARTMENT WHERE FATHER_ID =@p_SECUR_CODE))
280
			--OR (A.SECUR_CODE IN (SELECT DEP_ID FROM CM_DEPARTMENT WHERE FATHER_ID =@p_DEP_ID))
281
		)
282
	-- PAGING END
283
ELSE
284

    
285
-- PAGING BEGIN
286
	SELECT TOP(CONVERT(INT,@P_TOP))A.*, B.AUTH_STATUS_NAME,D.BRANCH_ID, D.BRANCH_CODE,
287
				DE.DEP_NAME,DE.DEP_CODE,
288
				dbo.FN_GET_CHINHANH(D.BRANCH_ID,'KV') KHU_VUC,
289
				dbo.FN_GET_CHINHANH(D.BRANCH_ID,'CN') CHI_NHANH, 
290
				D.BRANCH_NAME PGD, D.TAX_NO,E.POS_NAME, E.EMP_CODE,
291
				--STUFF( (select ',' + R.[Name] FOR XML PATH(''), TYPE).value('.[1]', 'nvarchar(max)'), 1, 1, '') RoleName2
292
				T.RoleName2, CMA.ACC_NUM, CMA.ACC_NAME, CMA.ACC_TYPE,
293
				D.BRANCH_NAME AS BR_NAME, D.BRANCH_CODE + '-'+ D.BRANCH_NAME AS BR_FULL_NAME,
294
				DE.DEP_CODE +'-'+ DE.DEP_NAME AS DP_FULL_NAME,
295
				K.DVDM_ID AS KHOI_ID, K.DVDM_CODE AS KHOI_CODE, K.DVDM_NAME AS KHOI_NAME
296
			-- SELECT END
297
	FROM TL_USER A
298
		INNER JOIN CM_AUTH_STATUS B ON B.AUTH_STATUS = A.AUTH_STATUS
299
		LEFT JOIN CM_BRANCH D ON  D.BRANCH_ID = A.TLSUBBRID
300
		LEFT JOIN CM_DEPARTMENT DE ON A.DEP_ID = DE.DEP_ID
301
		--LEFT JOIN AbpUserRoles UR  ON A.ID = UR.UserId
302
		--LEFT JOIN AbpRoles R ON R.Id = UR.RoleId
303
		-- GIANT 16/09/2021
304
		LEFT JOIN CM_EMPLOYEE_LOG E ON A.TLNANME = E.USER_DOMAIN
305
		LEFT JOIN CM_ACCOUNT_PAY CMA ON A.TLNANME = CMA.REF_ID
306
		INNER JOIN
307
		(SELECT A2.ID,
308
			(SELECT stuff((SELECT ',' + CONVERT(VARCHAR(MAX),R1.[DisplayName])
309
			FROM TL_USER A1
310
				LEFT JOIN AbpUserRoles UR1  ON A1.ID = UR1.UserId
311
				LEFT JOIN AbpRoles R1 ON R1.Id = UR1.RoleId
312
			WHERE A1.ID=A2.ID AND R1.DisplayName  IN ('QLK','KSV')
313
			FOR XML PATH ('')
314
			), 1, 1, '')) AS [RoleName2]
315
		FROM TL_USER A2
316
		GROUP BY A2.ID) T ON T.ID=A.ID
317
		LEFT JOIN CM_DVDM K ON DE.KHOI_ID = K.DVDM_ID AND K.IS_KHOI = '1'
318

    
319
	 WHERE 1 = 1
320
		AND (A.TLID LIKE '%' + @p_TLID + '%' OR  @p_TLID IS NULL OR @p_TLID = '')
321
		AND (A.TLNANME LIKE '%' + @p_TLNANME + '%' OR  @p_TLNANME IS NULL OR @p_TLNANME = '')
322
		AND (A.Password LIKE '%' + @p_Password + '%' OR  @p_Password IS NULL OR @p_Password = '')
323
		AND (A.TLFullName LIKE '%' + @p_TLFullName + '%' OR  @p_TLFullName IS NULL OR @p_TLFullName = '')
324
		--AND (A.TLSUBBRID LIKE '%' + @p_TLSUBBRID + '%' OR  @p_TLSUBBRID IS NULL OR @p_TLSUBBRID = '')
325
		AND (A.BRANCH_NAME LIKE '%' + @p_BRANCH_NAME + '%' OR  @p_BRANCH_NAME IS NULL OR @p_BRANCH_NAME = '')
326
		AND (A.BRANCH_TYPE LIKE '%' + @p_BRANCH_TYPE + '%' OR  @p_BRANCH_TYPE IS NULL OR @p_BRANCH_TYPE = '')
327
		AND (A.EMAIL LIKE '%' + @p_EMAIL + '%' OR  @p_EMAIL IS NULL OR @p_EMAIL = '')
328
		AND (A.ADDRESS LIKE '%' + @p_ADDRESS + '%' OR  @p_ADDRESS IS NULL OR @p_ADDRESS = '')
329
		AND (A.PHONE LIKE '%' + @p_PHONE + '%' OR  @p_PHONE IS NULL OR @p_PHONE = '')
330
		AND (A.AUTH_STATUS LIKE '%' + @p_AUTH_STATUS + '%' OR  @p_AUTH_STATUS IS NULL OR @p_AUTH_STATUS = '')
331
		--AND (A.MARKER_ID LIKE '%' + @p_MARKER_ID + '%' OR  @p_MARKER_ID IS NULL OR @p_MARKER_ID = '')
332
		AND (A.AUTH_ID LIKE '%' + @p_AUTH_ID + '%' OR  @p_AUTH_ID IS NULL OR @p_AUTH_ID = '')
333
		AND (DATEDIFF(DAY,A.APPROVE_DT ,CONVERT(DATETIME, @p_APPROVE_DT, 103)) = 0 OR  @p_APPROVE_DT IS NULL OR @p_APPROVE_DT = '')
334
		AND (A.ISAPPROVE LIKE '%' + @p_ISAPPROVE + '%' OR  @p_ISAPPROVE IS NULL OR @p_ISAPPROVE = '')
335
		AND (DATEDIFF(DAY,A.Birthday ,CONVERT(DATETIME, @p_Birthday, 103)) = 0 OR  @p_Birthday IS NULL OR @p_Birthday = '')
336
		AND (A.ISFIRSTTIME LIKE '%' + @p_ISFIRSTTIME + '%' OR  @p_ISFIRSTTIME IS NULL OR @p_ISFIRSTTIME = '')
337
--		AND (A.RoleName <> 'DISABLE' OR A.RoleName IS NULL) 
338
    AND T.RoleName2 <> 'DISABLE' -- NGUYENTD 22042024_SECRETKEY: CHECK ROLE Ở BẢNG ROLE THAY VÌ BẢNG TL_USER
339
       AND (A.TLSUBBRID = @p_BRANCH_LOGIN OR @p_BRANCH_LOGIN IS NULL OR @p_BRANCH_LOGIN = '')
340

    
341
		--AND (
342
		--	(A.SECUR_CODE LIKE '%' + @p_SECUR_CODE + '%'
343
		--		--OR (SELECT TOP 1 TRM.DEP_ID FROM TL_SYS_ROLE_MAPPING TRM 
344
		--		--	WHERE TRM.TLNAME = A.TLNANME 
345
		--		--	AND GETDATE() >= TRM.EFF_DATE AND GETDATE() <= TRM.EXP_DATE
346
		--		--	) LIKE '%' + @p_SECUR_CODE + '%'
347
		--		----------BAODNQ 30/9/2022 : Thêm xử lý tìm kiếm ủy quyền kiêm nhiệm--------
348
		--		OR EXISTS(SELECT * FROM TL_SYS_ROLE_MAPPING TRM 
349
		--					WHERE TRM.TLNAME = A.TLNANME 
350
		--					AND CONVERT(DATE,GETDATE(),103) >= TRM.EFF_DATE 
351
		--					AND CONVERT(DATE,GETDATE(),103) <= TRM.EXP_DATE
352
		--					AND TRM.DEP_ID = @p_SECUR_CODE
353
		--			)
354
		--		OR A.DEP_ID IN (SELECT DEP_ID FROM TL_SYS_ROLE_MAPPING TRM 
355
		--					WHERE 1=1
356
		--					AND CONVERT(DATE,GETDATE(),103) >= TRM.EFF_DATE 
357
		--					AND CONVERT(DATE,GETDATE(),103) <= TRM.EXP_DATE
358
		--					AND TRM.TLNAME = @p_MARKER_ID)
359
		--		OR (@p_TLSUBBRID <> 'DV0001' AND A.TLSUBBRID =@p_TLSUBBRID)
360
		--		OR (@BRANCH_ID <> 'DV0001' AND A.TLSUBBRID =@BRANCH_ID)
361
		--	) 
362
		--	OR (@p_DEP_ID IS NULL OR @p_DEP_ID = '' OR @p_SECUR_CODE IS NULL OR @p_SECUR_CODE ='')
363
		--	OR (A.SECUR_CODE IN (SELECT DEP_ID FROM CM_DEPARTMENT WHERE FATHER_ID =@p_SECUR_CODE))
364
		--	OR (A.SECUR_CODE IN (SELECT DEP_ID FROM CM_DEPARTMENT WHERE FATHER_ID =@p_DEP_ID))
365
		--)
366
		--------------BAODNQ 17/11/2022 : CHỈNH SỬA LẠI ĐIỀU KIỆN TÌM KIẾM THEO SECUR_CODE-------------------
367
		AND(
368
			(A.SECUR_CODE IN (SELECT DEP_ID FROM @t_DEP_ID_TMP)
369
				OR EXISTS(SELECT * FROM TL_SYS_ROLE_MAPPING TRM 
370
							WHERE TRM.TLNAME = A.TLNANME 
371
							AND CONVERT(DATE,GETDATE(),103) >= TRM.EFF_DATE 
372
							AND CONVERT(DATE,GETDATE(),103) <= TRM.EXP_DATE
373
							AND TRM.DEP_ID IN (SELECT DEP_ID FROM @t_DEP_ID_TMP)
374
					)
375
			)
376
			OR (@p_SECUR_CODE IS NULL OR @p_SECUR_CODE = '')
377
		)
378
		---------------ENDBAODNQ-------------------
379
		AND (A.TLNANME != 'admin')
380
		--AND (A.TLSUBBRID IN (SELECT BRANCH_ID FROM  CM_BRANCH_GETCHILDID(@p_TLSUBBRID)))
381
		--AND ((@P_LEVEL = 'ALL' AND A.TLSUBBRID IN (SELECT BRANCH_ID from @tmp)
382
		--OR (@P_LEVEL = 'UNIT' AND A.TLSUBBRID = @p_TLSUBBRID)) OR @p_TLSUBBRID = '' OR @p_TLSUBBRID IS NULL
383

    
384
		--)
385
		AND(
386
			(@P_LEVEL = 'ALL'
387
				AND (A.TLSUBBRID IN (SELECT BRANCH_ID from @tmp)
388
					--OR (SELECT TOP 1 TRM.BRANCH_ID
389
					--		FROM TL_SYS_ROLE_MAPPING TRM
390
					--		WHERE TRM.TLNAME = A.TLNANME
391
					--		AND GETDATE() >= TRM.EFF_DATE AND GETDATE() <= TRM.EXP_DATE
392
					--	) IN (SELECT BRANCH_ID from @tmp)
393
					----------BAODNQ 30/9/2022 : Thêm xử lý tìm kiếm ủy quyền kiêm nhiệm--------
394
					OR EXISTS(SELECT *
395
							FROM TL_SYS_ROLE_MAPPING TRM
396
							WHERE TRM.TLNAME = A.TLNANME
397
							AND CONVERT(DATE,GETDATE(),103) >= TRM.EFF_DATE 
398
							AND CONVERT(DATE,GETDATE(),103) <= TRM.EXP_DATE
399
							AND TRM.BRANCH_ID IN (SELECT BRANCH_ID from @tmp)
400
						)
401
					--OR A.DEP_ID IN (SELECT DEP_ID FROM TL_SYS_ROLE_MAPPING TRM 
402
					--		WHERE 1=1
403
					--		AND CONVERT(DATE,GETDATE(),103) >= TRM.EFF_DATE 
404
					--		AND CONVERT(DATE,GETDATE(),103) <= TRM.EXP_DATE
405
					--		AND TRM.TLNAME = @p_MARKER_ID)
406
					OR (@BRANCH_ID <> 'DV0001' AND A.TLSUBBRID =@BRANCH_ID)
407
					)
408
			)
409
			OR(@P_LEVEL = 'UNIT'
410
				AND (A.TLSUBBRID = @p_TLSUBBRID
411
					--OR (SELECT TOP 1 TRM.BRANCH_ID
412
					--		FROM TL_SYS_ROLE_MAPPING TRM
413
					--		WHERE TRM.TLNAME = A.TLNANME
414
					--		AND GETDATE() >= TRM.EFF_DATE AND GETDATE() <= TRM.EXP_DATE
415
					--	) = @p_TLSUBBRID
416
					----------BAODNQ 30/9/2022 : Thêm xử lý tìm kiếm ủy quyền kiêm nhiệm--------
417
					OR EXISTS(SELECT *
418
							FROM TL_SYS_ROLE_MAPPING TRM
419
							WHERE TRM.TLNAME = A.TLNANME
420
							AND CONVERT(DATE,GETDATE(),103) >= TRM.EFF_DATE 
421
							AND CONVERT(DATE,GETDATE(),103) <= TRM.EXP_DATE
422
							AND TRM.BRANCH_ID = @p_TLSUBBRID
423
						)
424
					--OR A.DEP_ID IN (SELECT DEP_ID FROM TL_SYS_ROLE_MAPPING TRM 
425
					--		WHERE 1=1
426
					--		AND CONVERT(DATE,GETDATE(),103) >= TRM.EFF_DATE 
427
					--		AND CONVERT(DATE,GETDATE(),103) <= TRM.EXP_DATE
428
					--		AND TRM.TLNAME = @p_MARKER_ID)
429
					OR (@BRANCH_ID <> 'DV0001' AND A.TLSUBBRID =@BRANCH_ID)
430
					)
431
			)
432
			--OR @BRANCH_ID = '' OR @BRANCH_ID IS NULL
433
			OR(@p_TLSUBBRID IS NULL OR @p_TLSUBBRID = '')
434
		)
435
		----------BAODNQ 22/3/2022 : Thêm điều kiện search theo phòng ban------
436

    
437
		--------------BAODNQ 17/11/2022 : CHỈNH SỬA LẠI ĐIỀU KIỆN TÌM KIẾM THEO DEP_ID-------------------
438
		AND(
439
			(A.DEP_ID IN (SELECT DEP_ID FROM @t_DEP_ID_TMP)
440
				OR EXISTS(SELECT * FROM TL_SYS_ROLE_MAPPING TRM 
441
							WHERE TRM.TLNAME = A.TLNANME 
442
							AND CONVERT(DATE,GETDATE(),103) >= TRM.EFF_DATE 
443
							AND CONVERT(DATE,GETDATE(),103) <= TRM.EXP_DATE
444
							AND TRM.DEP_ID IN (SELECT DEP_ID FROM @t_DEP_ID_TMP)
445
					)
446
			)
447
			OR(@p_DEP_ID IS NULL OR @p_DEP_ID = '')
448
		)
449
	-- PAGING END
450
COMMIT TRANSACTION
451

    
452

    
453
END -- PAGING
454

    
455
GO