Project

General

Profile

2.0 TL_USER_SEARCH.txt

Luc Tran Van, 03/18/2021 10:46 AM

 
1

    
2
/*
3
[dbo].[TL_USER_Search]
4
@p_TLID	= NULL,
5
@p_TLNANME	 = '',
6
@p_Password	 = '',
7
@p_TLFullName   = NULL,
8
@p_TLSUBBRID	= 'DV0001',
9
@p_BRANCH_NAME	 = NULL,
10
@p_BRANCH_TYPE	= NULL,
11
@p_RoleName	 = NULL,
12
@p_EMAIL	 = NULL,
13
@p_ADDRESS	= NULL,
14
@p_PHONE	 = NULL,
15
@p_AUTH_STATUS  = NULL,
16
@p_MARKER_ID	 = NULL,
17
@p_AUTH_ID	 = NULL,
18
@p_APPROVE_DT	= NULL,
19
@p_ISAPPROVE	  = NULL,
20
@p_Birthday	 = NULL,
21
@p_ISFIRSTTIME	  = NULL,
22
@p_SECUR_CODE	 = NULL,
23
@p_TOP	= 100,
24
@p_Level = 'unit'
25

    
26
*/
27
ALTER PROCEDURE [dbo].[TL_USER_Search]
28
@p_TLID	varchar(15)  = NULL,
29
@p_TLNANME	varchar(15)  = NULL,
30
@p_Password	varchar(50)  = NULL,
31
@p_TLFullName	nvarchar(200)  = NULL,
32
@p_TLSUBBRID	varchar(15)  = NULL,
33
@p_BRANCH_NAME	nvarchar(200)  = NULL,
34
@p_BRANCH_TYPE	varchar(5)  = NULL,
35
@p_RoleName	varchar(20)  = NULL,
36
@p_EMAIL	varchar(50)  = NULL,
37
@p_ADDRESS	varchar(100)  = NULL,
38
@p_PHONE	varchar(15)  = NULL,
39
@p_AUTH_STATUS	varchar(1)  = NULL,
40
@p_MARKER_ID	varchar(12)  = NULL,
41
@p_AUTH_ID	varchar(12)  = NULL,
42
@p_APPROVE_DT	VARCHAR(20) = NULL,
43
@p_ISAPPROVE	varchar(1)  = NULL,
44
@p_Birthday	VARCHAR(20) = NULL,
45
@p_ISFIRSTTIME	varchar(1)  = NULL,
46
@p_SECUR_CODE	varchar(50)  = NULL,
47
@p_TOP	INT = 10,
48
@P_LEVEL varchar(10) = NULL
49
AS
50
	--Validation is here
51
/*
52
	DECLARE @ERRORSYS NVARCHAR(15) = '' 
53
	IF ( [NOT] EXISTS ( SELECT * FROM [TABLE] WHERE  [CONDITION] ))
54
		 SET @ERRORSYS = ''
55
	IF @ERRORSYS <> '' 
56
	BEGIN
57
		SELECT ErrorCode Result, ''  CAR_ID, ErrorDesc ErrorDesc FROM SYS_ERROR WHERE ErrorCode = @ERRORSYS
58
		RETURN '0'
59
	END */
60
--BEGIN TRANSACTION
61
DECLARE @BRANCH_LOGIN VARCHAR(15), @BRANCH_TYPE VARCHAR(15) = ''
62
SET @BRANCH_LOGIN =(SELECT TOP 1 BRANCH_ID FROM CM_DEPARTMENT WHERE DEP_ID=@p_SECUR_CODE)
63
SET @BRANCH_TYPE =(SELECT TOP 1 BRANCH_TYPE FROM CM_BRANCH WHERE BRANCH_ID =@BRANCH_LOGIN)
64
DECLARE @DEP_AUTH TABLE (DEP_AUTH VARCHAR(15))
65
INSERT INTO @DEP_AUTH SELECT DEP_ID FROM TL_SYS_ROLE_MAPPING WHERE TLNAME =@p_EMAIL AND CONVERT(DATE,GETDATE(),103) >= CONVERT(DATE,EFF_DATE, 103) AND CONVERT(DATE, GETDATE(),103) <=CONVERT(DATE,EXP_DATE, 103)
66
IF @P_LEVEL = 'LOGIN'
67
BEGIN
68
	SELECT TOP 1 A.*, B.AUTH_STATUS_NAME, D.BRANCH_CODE,
69
		dbo.FN_GET_CHINHANH(D.BRANCH_ID,'KV') KHU_VUC,
70
		dbo.FN_GET_CHINHANH(D.BRANCH_ID,'CN') CHI_NHANH, 
71
		D.BRANCH_NAME PGD, D.TAX_NO,DP.DEP_NAME, DP.DEP_CODE, '' POS_NAME, '' EMP_CODE
72
	FROM TL_USER A
73
		INNER JOIN CM_AUTH_STATUS B ON B.AUTH_STATUS = A.AUTH_STATUS
74
		LEFT JOIN CM_BRANCH D ON  D.BRANCH_ID = A.TLSUBBRID
75
		LEFT JOIN CM_DEPARTMENT DP ON A.SECUR_CODE = DP.DEP_ID
76
	 WHERE A.TLNANME = @p_TLNANME AND A.AUTH_STATUS = 'A'
77
END
78
ELSE
79
BEGIN
80
-- Toannv
81
declare @tmp table(BRANCH_ID varchar(15))
82
insert into @tmp  SELECT BRANCH_ID  FROM [dbo].[CM_BRANCH_GETCHILDID](@p_TLSUBBRID)
83

    
84
IF(@p_TOP = NULL OR @P_TOP = '' OR @P_TOP = 0)
85
SELECT A.*, B.AUTH_STATUS_NAME, D.BRANCH_CODE,
86
		dbo.FN_GET_CHINHANH(D.BRANCH_ID,'KV') KHU_VUC,
87
		dbo.FN_GET_CHINHANH(D.BRANCH_ID,'CN') CHI_NHANH, 
88
		D.BRANCH_NAME PGD, D.TAX_NO, DP.DEP_NAME, DP.DEP_CODE,E.POS_NAME, E.EMP_CODE
89
FROM TL_USER A
90
	INNER JOIN CM_AUTH_STATUS B ON B.AUTH_STATUS = A.AUTH_STATUS
91
	LEFT JOIN CM_BRANCH D ON  D.BRANCH_ID = A.TLSUBBRID
92
	LEFT JOIN CM_DEPARTMENT DP ON A.SECUR_CODE = DP.DEP_ID
93
	LEFT JOIN CM_EMPLOYEE_LOG E ON A.TLNANME = E.USER_DOMAIN
94
 WHERE 1 = 1
95
	AND (A.TLID LIKE '%' + @p_TLID + '%' OR  @p_TLID IS NULL OR @p_TLID = '')
96
	AND (A.TLNANME LIKE '%' + @p_TLNANME + '%' OR  @p_TLNANME IS NULL OR @p_TLNANME = '')
97
	AND (A.Password LIKE '%' + @p_Password + '%' OR  @p_Password IS NULL OR @p_Password = '')
98
	AND (A.TLFullName LIKE '%' + @p_TLFullName + '%' OR  @p_TLFullName IS NULL OR @p_TLFullName = '')
99
	--AND (A.TLSUBBRID LIKE '%' + @p_TLSUBBRID + '%' OR  @p_TLSUBBRID IS NULL OR @p_TLSUBBRID = '')
100
	AND (A.BRANCH_NAME LIKE '%' + @p_BRANCH_NAME + '%' OR  @p_BRANCH_NAME IS NULL OR @p_BRANCH_NAME = '')
101
	AND (A.BRANCH_TYPE LIKE '%' + @p_BRANCH_TYPE + '%' OR  @p_BRANCH_TYPE IS NULL OR @p_BRANCH_TYPE = '')
102
	--AND (A.RoleName LIKE '%' + @p_RoleName + '%' OR  @p_RoleName IS NULL OR @p_RoleName = '')
103
	AND (A.RoleName = @p_RoleName  OR  @p_RoleName IS NULL OR @p_RoleName = '')
104
	--AND (A.EMAIL LIKE '%' + @p_EMAIL + '%' OR  @p_EMAIL IS NULL OR @p_EMAIL = '')
105
	AND (A.ADDRESS LIKE '%' + @p_ADDRESS + '%' OR  @p_ADDRESS IS NULL OR @p_ADDRESS = '')
106
	AND (A.PHONE LIKE '%' + @p_PHONE + '%' OR  @p_PHONE IS NULL OR @p_PHONE = '')
107
	AND (A.AUTH_STATUS LIKE '%' + @p_AUTH_STATUS + '%' OR  @p_AUTH_STATUS IS NULL OR @p_AUTH_STATUS = '')
108
	AND (A.MARKER_ID LIKE '%' + @p_MARKER_ID + '%' OR  @p_MARKER_ID IS NULL OR @p_MARKER_ID = '')
109
	AND (A.AUTH_ID LIKE '%' + @p_AUTH_ID + '%' OR  @p_AUTH_ID IS NULL OR @p_AUTH_ID = '')
110
	AND (DATEDIFF(DAY,A.APPROVE_DT ,CONVERT(DATETIME, @p_APPROVE_DT, 103)) = 0 OR  @p_APPROVE_DT IS NULL OR @p_APPROVE_DT = '')
111
	AND (A.ISAPPROVE LIKE '%' + @p_ISAPPROVE + '%' OR  @p_ISAPPROVE IS NULL OR @p_ISAPPROVE = '')
112
	AND (DATEDIFF(DAY,A.Birthday ,CONVERT(DATETIME, @p_Birthday, 103)) = 0 OR  @p_Birthday IS NULL OR @p_Birthday = '')
113
	AND (A.ISFIRSTTIME LIKE '%' + @p_ISFIRSTTIME + '%' OR  @p_ISFIRSTTIME IS NULL OR @p_ISFIRSTTIME = '')
114
	AND (A.SECUR_CODE LIKE '%' + @p_SECUR_CODE + '%' OR  @p_SECUR_CODE IS NULL OR @p_SECUR_CODE = '')
115
	AND (A.TLNANME != 'admin')
116
	AND (A.RoleName <> 'DISABLE')
117
	--AND (A.TLSUBBRID IN (SELECT BRANCH_ID FROM  CM_BRANCH_GETCHILDID(@p_TLSUBBRID)))
118
	AND ((@P_LEVEL = 'ALL' AND A.TLSUBBRID IN (SELECT BRANCH_ID from @tmp)
119
	OR (@P_LEVEL = 'UNIT' AND A.TLSUBBRID = @p_TLSUBBRID)) OR @p_TLSUBBRID = '' OR @p_TLSUBBRID IS NULL
120

    
121
	)
122
ELSE
123
SELECT TOP(CONVERT(INT,@P_TOP))A.*, B.AUTH_STATUS_NAME, D.BRANCH_CODE,
124
		dbo.FN_GET_CHINHANH(D.BRANCH_ID,'KV') KHU_VUC,
125
		dbo.FN_GET_CHINHANH(D.BRANCH_ID,'CN') CHI_NHANH, 
126
		D.BRANCH_NAME PGD, D.TAX_NO,DP.DEP_NAME, DP.DEP_CODE,E.POS_NAME, E.EMP_CODE
127
FROM TL_USER A
128
	INNER JOIN CM_AUTH_STATUS B ON B.AUTH_STATUS = A.AUTH_STATUS
129
	LEFT JOIN CM_BRANCH D ON  D.BRANCH_ID = A.TLSUBBRID
130
	LEFT JOIN CM_DEPARTMENT DP ON A.SECUR_CODE = DP.DEP_ID
131
	LEFT JOIN CM_EMPLOYEE_LOG E ON A.TLNANME = E.USER_DOMAIN
132
 WHERE 1 = 1
133
	AND (A.TLID LIKE '%' + @p_TLID + '%' OR  @p_TLID IS NULL OR @p_TLID = '')
134
	AND (A.TLNANME LIKE '%' + @p_TLNANME + '%' OR  @p_TLNANME IS NULL OR @p_TLNANME = '')
135
	AND (A.Password LIKE '%' + @p_Password + '%' OR  @p_Password IS NULL OR @p_Password = '')
136
	AND (A.TLFullName LIKE '%' + @p_TLFullName + '%' OR  @p_TLFullName IS NULL OR @p_TLFullName = '')
137
	--AND (A.TLSUBBRID LIKE '%' + @p_TLSUBBRID + '%' OR  @p_TLSUBBRID IS NULL OR @p_TLSUBBRID = '')
138
	AND (A.BRANCH_NAME LIKE '%' + @p_BRANCH_NAME + '%' OR  @p_BRANCH_NAME IS NULL OR @p_BRANCH_NAME = '')
139
	AND (A.BRANCH_TYPE LIKE '%' + @p_BRANCH_TYPE + '%' OR  @p_BRANCH_TYPE IS NULL OR @p_BRANCH_TYPE = '')
140
	--AND (A.RoleName LIKE '%' + @p_RoleName + '%' OR  @p_RoleName IS NULL OR @p_RoleName = '')
141
	AND (A.RoleName = @p_RoleName  OR  @p_RoleName IS NULL OR @p_RoleName = '')
142
	--AND (A.EMAIL LIKE '%' + @p_EMAIL + '%' OR  @p_EMAIL IS NULL OR @p_EMAIL = '')
143
	AND (A.ADDRESS LIKE '%' + @p_ADDRESS + '%' OR  @p_ADDRESS IS NULL OR @p_ADDRESS = '')
144
	AND (A.PHONE LIKE '%' + @p_PHONE + '%' OR  @p_PHONE IS NULL OR @p_PHONE = '')
145
	AND (A.AUTH_STATUS LIKE '%' + @p_AUTH_STATUS + '%' OR  @p_AUTH_STATUS IS NULL OR @p_AUTH_STATUS = '')
146
	AND (A.MARKER_ID LIKE '%' + @p_MARKER_ID + '%' OR  @p_MARKER_ID IS NULL OR @p_MARKER_ID = '')
147
	AND (A.AUTH_ID LIKE '%' + @p_AUTH_ID + '%' OR  @p_AUTH_ID IS NULL OR @p_AUTH_ID = '')
148
	AND (DATEDIFF(DAY,A.APPROVE_DT ,CONVERT(DATETIME, @p_APPROVE_DT, 103)) = 0 OR  @p_APPROVE_DT IS NULL OR @p_APPROVE_DT = '')
149
	AND (A.ISAPPROVE LIKE '%' + @p_ISAPPROVE + '%' OR  @p_ISAPPROVE IS NULL OR @p_ISAPPROVE = '')
150
	AND (DATEDIFF(DAY,A.Birthday ,CONVERT(DATETIME, @p_Birthday, 103)) = 0 OR  @p_Birthday IS NULL OR @p_Birthday = '')
151
	AND (A.ISFIRSTTIME LIKE '%' + @p_ISFIRSTTIME + '%' OR  @p_ISFIRSTTIME IS NULL OR @p_ISFIRSTTIME = '')
152
	--AND (A.SECUR_CODE LIKE '%' + @p_SECUR_CODE + '%' OR  @p_SECUR_CODE IS NULL OR @p_SECUR_CODE = '' OR (@p_SECUR_CODE ='DEP000000000014' AND A.TLNANME IN ('tuanva','sanggt','hoacq'))
153
	AND (A.SECUR_CODE LIKE '%' + @p_SECUR_CODE + '%' OR  @p_SECUR_CODE IS NULL OR @p_SECUR_CODE = '' OR (@p_SECUR_CODE ='DEP000000000014' AND A.TLNANME IN ('1','2','3') OR(A.SECUR_CODE IN (SELECT * FROM @DEP_AUTH)))
154
	OR(@BRANCH_TYPE <>'HS' AND A.TLSUBBRID = @BRANCH_LOGIN))
155
	AND (A.TLNANME != 'admin')
156
	AND (A.RoleName <> 'DISABLE')
157
	--AND (A.TLSUBBRID IN (SELECT BRANCH_ID FROM  CM_BRANCH_GETCHILDID(@p_TLSUBBRID)))
158
	AND ((@P_LEVEL = 'ALL' AND A.TLSUBBRID IN (SELECT BRANCH_ID from @tmp)
159
	OR (@P_LEVEL = 'UNIT' AND A.TLSUBBRID = @p_TLSUBBRID)) OR @p_TLSUBBRID = '' OR @p_TLSUBBRID IS NULL
160

    
161
	)
162
--COMMIT TRANSACTION
163
END