Project

General

Profile

stored_tl_user_search_220322.txt

Luc Tran Van, 03/22/2022 12:04 PM

 
1

    
2
GO
3
/****** Object:  StoredProcedure [dbo].[TL_USER_Search]    Script Date: 22-Mar-22 12:02:00 PM ******/
4
SET ANSI_NULLS ON
5
GO
6
SET QUOTED_IDENTIFIER ON
7
GO
8

    
9

    
10
/*
11
[dbo].[TL_USER_Search]
12
@p_TLID	= NULL,
13
@p_TLNANME	 = '',
14
@p_Password	 = '',
15
@p_TLFullName   = NULL,
16
@p_BRANCH_ID	= 'DV0001',
17
@p_BRANCH_NAME	 = NULL,
18
@p_BRANCH_TYPE	= NULL,
19
@p_RoleName	 = NULL,
20
@p_EMAIL	 = NULL,
21
@p_ADDRESS	= NULL,
22
@p_PHONE	 = NULL,
23
@p_AUTH_STATUS  = NULL,
24
@p_MARKER_ID	 = NULL,
25
@p_AUTH_ID	 = NULL,
26
@p_APPROVE_DT	= NULL,
27
@p_ISAPPROVE	  = NULL,
28
@p_Birthday	 = NULL,
29
@p_ISFIRSTTIME	  = NULL,
30
@p_SECUR_CODE	 = NULL,
31
@p_TOP	= 100,
32
@p_Level = 'unit'
33

    
34
*/
35
ALTER PROCEDURE [dbo].[TL_USER_Search]
36
@p_TLID	varchar(15)  = NULL,
37
@p_TLNANME	varchar(15)  = NULL,
38
@p_Password	varchar(50)  = NULL,
39
@p_TLFullName	nvarchar(200)  = NULL,
40
@p_BRANCH_ID	varchar(15)  = NULL,
41
@p_BRANCH_NAME	nvarchar(200)  = NULL,
42
@p_BRANCH_TYPE	varchar(5)  = NULL,
43
@p_RoleName	varchar(20)  = NULL,
44
@p_EMAIL	varchar(50)  = NULL,
45
@p_ADDRESS	varchar(100)  = NULL,
46
@p_PHONE	varchar(15)  = NULL,
47
@p_AUTH_STATUS	varchar(1)  = NULL,
48
@p_MARKER_ID	varchar(12)  = NULL,
49
@p_AUTH_ID	varchar(12)  = NULL,
50
@p_APPROVE_DT	VARCHAR(20) = NULL,
51
@p_ISAPPROVE	varchar(1)  = NULL,
52
@p_Birthday	VARCHAR(20) = NULL,
53
@p_ISFIRSTTIME	varchar(1)  = NULL,
54
@p_SECUR_CODE	varchar(50)  = NULL,
55
@p_DEP_ID	varchar(15)  = NULL,
56
@p_TOP	INT = 10,
57
@P_LEVEL varchar(10) = NULL
58
AS
59
	--Validation is here
60
/*
61
	DECLARE @ERRORSYS NVARCHAR(15) = '' 
62
	IF ( [NOT] EXISTS ( SELECT * FROM [TABLE] WHERE  [CONDITION] ))
63
		 SET @ERRORSYS = ''
64
	IF @ERRORSYS <> '' 
65
	BEGIN
66
		SELECT ErrorCode Result, ''  CAR_ID, ErrorDesc ErrorDesc FROM SYS_ERROR WHERE ErrorCode = @ERRORSYS
67
		RETURN '0'
68
	END */
69

    
70
BEGIN -- PAGING
71

    
72
BEGIN TRANSACTION
73

    
74
-- Toannv
75
declare @tmp table(BRANCH_ID varchar(15))
76
insert into @tmp  SELECT BRANCH_ID  FROM [dbo].[CM_BRANCH_GETCHILDID](@p_BRANCH_ID)
77

    
78
IF(@p_TOP IS NULL OR @P_TOP = '' OR @P_TOP = 0)
79
-- PAGING BEGIN
80
	SELECT A.*, B.AUTH_STATUS_NAME, D.BRANCH_CODE,
81
			DE.DEP_NAME,DE.DEP_CODE,
82
			dbo.FN_GET_CHINHANH(D.BRANCH_ID,'KV') KHU_VUC,
83
			dbo.FN_GET_CHINHANH(D.BRANCH_ID,'CN') CHI_NHANH, 
84
			D.BRANCH_NAME PGD, D.TAX_NO,E.POS_NAME, E.EMP_CODE,
85
			STUFF( (select ',' + R.[Name] FOR XML PATH(''), TYPE).value('.[1]', 'nvarchar(max)'), 1, 1, '') RoleName2
86
	-- SELECT END
87
	FROM TL_USER A
88
		INNER JOIN CM_AUTH_STATUS B ON B.AUTH_STATUS = A.AUTH_STATUS
89
		LEFT JOIN CM_BRANCH D ON  D.BRANCH_ID = A.TLSUBBRID
90
		LEFT JOIN CM_DEPARTMENT DE ON A.DEP_ID = DE.DEP_ID
91
		LEFT JOIN AbpUserRoles UR  ON A.ID = UR.UserId
92
		LEFT JOIN AbpRoles R ON R.Id = UR.RoleId
93
		-- GIANT 16/09/2021
94
		LEFT JOIN CM_EMPLOYEE_LOG E ON A.TLNANME = E.USER_DOMAIN
95

    
96
	 WHERE 1 = 1
97
		AND (A.TLID LIKE '%' + @p_TLID + '%' OR  @p_TLID IS NULL OR @p_TLID = '')
98
		AND (A.TLNANME LIKE '%' + @p_TLNANME + '%' OR  @p_TLNANME IS NULL OR @p_TLNANME = '')
99
		AND (A.Password LIKE '%' + @p_Password + '%' OR  @p_Password IS NULL OR @p_Password = '')
100
		AND (A.TLFullName LIKE '%' + @p_TLFullName + '%' OR  @p_TLFullName IS NULL OR @p_TLFullName = '')
101
		--AND (A.TLSUBBRID LIKE '%' + @p_BRANCH_ID + '%' OR  @p_BRANCH_ID IS NULL OR @p_BRANCH_ID = '')
102
		AND (A.BRANCH_NAME LIKE '%' + @p_BRANCH_NAME + '%' OR  @p_BRANCH_NAME IS NULL OR @p_BRANCH_NAME = '')
103
		AND (A.BRANCH_TYPE LIKE '%' + @p_BRANCH_TYPE + '%' OR  @p_BRANCH_TYPE IS NULL OR @p_BRANCH_TYPE = '')
104
		AND (A.RoleName LIKE '%' + @p_RoleName + '%' OR  @p_RoleName IS NULL OR @p_RoleName = '')
105
		AND (A.DEP_ID LIKE '%' + @p_DEP_ID + '%' OR  @p_DEP_ID IS NULL OR @p_DEP_ID = '')
106
		AND (A.EMAIL LIKE '%' + @p_EMAIL + '%' OR  @p_EMAIL IS NULL OR @p_EMAIL = '')
107
		AND (A.ADDRESS LIKE '%' + @p_ADDRESS + '%' OR  @p_ADDRESS IS NULL OR @p_ADDRESS = '')
108
		AND (A.PHONE LIKE '%' + @p_PHONE + '%' OR  @p_PHONE IS NULL OR @p_PHONE = '')
109
		AND (A.AUTH_STATUS LIKE '%' + @p_AUTH_STATUS + '%' OR  @p_AUTH_STATUS IS NULL OR @p_AUTH_STATUS = '')
110
		AND (A.MARKER_ID LIKE '%' + @p_MARKER_ID + '%' OR  @p_MARKER_ID IS NULL OR @p_MARKER_ID = '')
111
		AND (A.AUTH_ID LIKE '%' + @p_AUTH_ID + '%' OR  @p_AUTH_ID IS NULL OR @p_AUTH_ID = '')
112
		AND (DATEDIFF(DAY,A.APPROVE_DT ,CONVERT(DATETIME, @p_APPROVE_DT, 103)) = 0 OR  @p_APPROVE_DT IS NULL OR @p_APPROVE_DT = '')
113
		AND (A.ISAPPROVE LIKE '%' + @p_ISAPPROVE + '%' OR  @p_ISAPPROVE IS NULL OR @p_ISAPPROVE = '')
114
		AND (DATEDIFF(DAY,A.Birthday ,CONVERT(DATETIME, @p_Birthday, 103)) = 0 OR  @p_Birthday IS NULL OR @p_Birthday = '')
115
		AND (A.ISFIRSTTIME LIKE '%' + @p_ISFIRSTTIME + '%' OR  @p_ISFIRSTTIME IS NULL OR @p_ISFIRSTTIME = '')
116
		AND (A.SECUR_CODE LIKE '%' + @p_SECUR_CODE + '%' OR  @p_SECUR_CODE IS NULL OR @p_SECUR_CODE = '')
117
		AND (A.TLNANME != 'admin')
118
		--AND (A.TLSUBBRID IN (SELECT BRANCH_ID FROM  CM_BRANCH_GETCHILDID(@p_BRANCH_ID)))
119
		AND ((@P_LEVEL = 'ALL' AND A.TLSUBBRID IN (SELECT BRANCH_ID from @tmp)
120
		OR (@P_LEVEL = 'UNIT' AND A.TLSUBBRID = @p_BRANCH_ID)) OR @p_BRANCH_ID = '' OR @p_BRANCH_ID IS NULL
121

    
122
		)
123
	-- PAGING END
124
ELSE
125

    
126
-- PAGING BEGIN
127
	SELECT TOP(CONVERT(INT,@P_TOP))A.*, B.AUTH_STATUS_NAME, D.BRANCH_CODE,
128
				DE.DEP_NAME,DE.DEP_CODE,
129
				dbo.FN_GET_CHINHANH(D.BRANCH_ID,'KV') KHU_VUC,
130
				dbo.FN_GET_CHINHANH(D.BRANCH_ID,'CN') CHI_NHANH, 
131
				D.BRANCH_NAME PGD, D.TAX_NO,E.POS_NAME, E.EMP_CODE,
132
				STUFF( (select ',' + R.[Name] FOR XML PATH(''), TYPE).value('.[1]', 'nvarchar(max)'), 1, 1, '') RoleName2
133
			-- SELECT END
134
	FROM TL_USER A
135
		INNER JOIN CM_AUTH_STATUS B ON B.AUTH_STATUS = A.AUTH_STATUS
136
		LEFT JOIN CM_BRANCH D ON  D.BRANCH_ID = A.TLSUBBRID
137
		LEFT JOIN CM_DEPARTMENT DE ON A.DEP_ID = DE.DEP_ID
138
		LEFT JOIN AbpUserRoles UR  ON A.ID = UR.UserId
139
		LEFT JOIN AbpRoles R ON R.Id = UR.RoleId
140
		-- GIANT 16/09/2021
141
		LEFT JOIN CM_EMPLOYEE_LOG E ON A.TLNANME = E.USER_DOMAIN
142
	 WHERE 1 = 1
143
		AND (A.TLID LIKE '%' + @p_TLID + '%' OR  @p_TLID IS NULL OR @p_TLID = '')
144
		AND (A.TLNANME LIKE '%' + @p_TLNANME + '%' OR  @p_TLNANME IS NULL OR @p_TLNANME = '')
145
		AND (A.Password LIKE '%' + @p_Password + '%' OR  @p_Password IS NULL OR @p_Password = '')
146
		AND (A.TLFullName LIKE '%' + @p_TLFullName + '%' OR  @p_TLFullName IS NULL OR @p_TLFullName = '')
147
		--AND (A.TLSUBBRID LIKE '%' + @p_BRANCH_ID + '%' OR  @p_BRANCH_ID IS NULL OR @p_BRANCH_ID = '')
148
		AND (A.BRANCH_NAME LIKE '%' + @p_BRANCH_NAME + '%' OR  @p_BRANCH_NAME IS NULL OR @p_BRANCH_NAME = '')
149
		AND (A.BRANCH_TYPE LIKE '%' + @p_BRANCH_TYPE + '%' OR  @p_BRANCH_TYPE IS NULL OR @p_BRANCH_TYPE = '')
150
		AND (A.RoleName LIKE '%' + @p_RoleName + '%' OR  @p_RoleName IS NULL OR @p_RoleName = '')
151
		AND (A.EMAIL LIKE '%' + @p_EMAIL + '%' OR  @p_EMAIL IS NULL OR @p_EMAIL = '')
152
		AND (A.ADDRESS LIKE '%' + @p_ADDRESS + '%' OR  @p_ADDRESS IS NULL OR @p_ADDRESS = '')
153
		AND (A.PHONE LIKE '%' + @p_PHONE + '%' OR  @p_PHONE IS NULL OR @p_PHONE = '')
154
		AND (A.AUTH_STATUS LIKE '%' + @p_AUTH_STATUS + '%' OR  @p_AUTH_STATUS IS NULL OR @p_AUTH_STATUS = '')
155
		AND (A.MARKER_ID LIKE '%' + @p_MARKER_ID + '%' OR  @p_MARKER_ID IS NULL OR @p_MARKER_ID = '')
156
		AND (A.AUTH_ID LIKE '%' + @p_AUTH_ID + '%' OR  @p_AUTH_ID IS NULL OR @p_AUTH_ID = '')
157
		AND (DATEDIFF(DAY,A.APPROVE_DT ,CONVERT(DATETIME, @p_APPROVE_DT, 103)) = 0 OR  @p_APPROVE_DT IS NULL OR @p_APPROVE_DT = '')
158
		AND (A.ISAPPROVE LIKE '%' + @p_ISAPPROVE + '%' OR  @p_ISAPPROVE IS NULL OR @p_ISAPPROVE = '')
159
		AND (DATEDIFF(DAY,A.Birthday ,CONVERT(DATETIME, @p_Birthday, 103)) = 0 OR  @p_Birthday IS NULL OR @p_Birthday = '')
160
		AND (A.ISFIRSTTIME LIKE '%' + @p_ISFIRSTTIME + '%' OR  @p_ISFIRSTTIME IS NULL OR @p_ISFIRSTTIME = '')
161
		AND (A.SECUR_CODE LIKE '%' + @p_SECUR_CODE + '%' OR  @p_SECUR_CODE IS NULL OR @p_SECUR_CODE = '')
162
		AND (A.TLNANME != 'admin')
163
		--AND (A.TLSUBBRID IN (SELECT BRANCH_ID FROM  CM_BRANCH_GETCHILDID(@p_BRANCH_ID)))
164
		AND ((@P_LEVEL = 'ALL' AND A.TLSUBBRID IN (SELECT BRANCH_ID from @tmp)
165
		OR (@P_LEVEL = 'UNIT' AND A.TLSUBBRID = @p_BRANCH_ID)) OR @p_BRANCH_ID = '' OR @p_BRANCH_ID IS NULL
166

    
167
		)
168
	-- PAGING END
169
COMMIT TRANSACTION
170

    
171

    
172
END -- PAGING