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
|