1
|
|
2
|
ALTER PROCEDURE dbo.CM_BRANCH_DEP_Search_v2
|
3
|
@p_BRANCH_ID varchar(15) = NULL,
|
4
|
@p_FATHER_ID varchar(15) = NULL,
|
5
|
@p_FATHER_CODE VARCHAR(15) = NULL,
|
6
|
@p_BRANCH_CODE varchar(15) = NULL,
|
7
|
@p_BRANCH_NAME nvarchar(200) = NULL,
|
8
|
@p_REGION_ID varchar(15) = NULL,
|
9
|
@P_REGION_CODE VARCHAR(15) = NULL,
|
10
|
@p_BRANCH_TYPE varchar(5) = NULL,
|
11
|
@p_ADDR nvarchar(200) = NULL,
|
12
|
@p_TEL varchar(20) = NULL,
|
13
|
@p_NOTES nvarchar(1000) = NULL,
|
14
|
@p_RECORD_STATUS varchar(1) = NULL,
|
15
|
@p_MAKER_ID varchar(15) = NULL,
|
16
|
@p_CREATE_DT VARCHAR(20) = NULL,
|
17
|
@p_AUTH_STATUS varchar(50) = NULL,
|
18
|
@p_CHECKER_ID varchar(15) = NULL,
|
19
|
@p_APPROVE_DT VARCHAR(20) = NULL,
|
20
|
@p_TOP INT = NULL,
|
21
|
@p_BRANCH_LOGIN varchar(15) = NULL,
|
22
|
@p_DEP_NAME NVARCHAR(500)=NULL,
|
23
|
@p_DEP_CODE VARCHAR(20) =NULL,
|
24
|
@p_DEP_ID VARCHAR(20) = NULL,
|
25
|
@p_USER_LOGIN VARCHAR(15) = NULL,
|
26
|
@p_TYPE_SEARCH VARCHAR(15) = NULL
|
27
|
AS
|
28
|
--Validation is here
|
29
|
/*
|
30
|
DECLARE @ERRORSYS NVARCHAR(15) = ''
|
31
|
IF ( [NOT] EXISTS ( SELECT * FROM [TABLE] WHERE [CONDITION] ))
|
32
|
SET @ERRORSYS = ''
|
33
|
IF @ERRORSYS <> ''
|
34
|
BEGIN
|
35
|
SELECT ErrorCode Result, '' CAR_ID, ErrorDesc ErrorDesc FROM SYS_ERROR WHERE ErrorCode = @ERRORSYS
|
36
|
RETURN '0'
|
37
|
END */
|
38
|
BEGIN -- PAGING
|
39
|
IF @p_TOP = 300 SET @p_TOP = 1000
|
40
|
DECLARE @LOAI_DONVI VARCHAR(20), @DEPT_LOGIN VARCHAR(15)
|
41
|
SET @DEPT_LOGIN = (SELECT SECUR_CODE FROM dbo.TL_USER WHERE TLNANME = @p_USER_LOGIN)
|
42
|
IF ((SELECT BRANCH_TYPE FROM dbo.CM_BRANCH WHERE BRANCH_ID = @p_BRANCH_LOGIN) <> 'HS')
|
43
|
SET @LOAI_DONVI = 'DVKD'
|
44
|
ELSE IF (EXISTS(SELECT DM.DVDM_ID
|
45
|
FROM dbo.PL_COSTCENTER_DT DT
|
46
|
LEFT JOIN PL_COSTCENTER CO ON DT.COST_ID = CO.COST_ID
|
47
|
LEFT JOIN dbo.CM_DEPARTMENT DE ON DE.DEP_ID = DT.DEP_ID
|
48
|
LEFT JOIN dbo.CM_DVDM DM ON DM.DVDM_ID = CO.DVDM_ID
|
49
|
WHERE DM.IS_DVDM = 1 AND DT.BRANCH_ID = @p_BRANCH_LOGIN AND DT.DEP_ID = @DEPT_LOGIN))
|
50
|
SET @LOAI_DONVI = 'DVDM'
|
51
|
ELSE
|
52
|
SET @LOAI_DONVI = 'HS'
|
53
|
|
54
|
IF(@p_TOP IS NULL OR @P_TOP = '' OR @P_TOP = 0)
|
55
|
-- PAGING BEGIN
|
56
|
SELECT A.*,
|
57
|
B.BRANCH_CODE AS F_BRANCH_CODE,
|
58
|
B.BRANCH_NAME AS F_BRANCH_NAME,CD.DEP_CODE,CD.DEP_NAME,CD.DEP_ID
|
59
|
-- SELECT END
|
60
|
FROM CM_BRANCH A
|
61
|
LEFT JOIN CM_BRANCH B ON A.FATHER_ID = B.BRANCH_ID
|
62
|
LEFT JOIN dbo.CM_DEPARTMENT CD ON CD.BRANCH_ID=A.BRANCH_ID AND A.BRANCH_TYPE='HS'
|
63
|
WHERE 1 = 1
|
64
|
AND (A.BRANCH_ID LIKE '%' + @p_BRANCH_ID + '%' OR @p_BRANCH_ID IS NULL OR @p_BRANCH_ID = '')
|
65
|
-- PHONGNT 17/10/22 THEM DIEU KIEN TIM KIEM PHONGBAN
|
66
|
AND (CD.DEP_ID = @p_DEP_ID OR @p_DEP_ID IS NULL OR @p_DEP_ID = '')
|
67
|
-- END
|
68
|
AND (A.FATHER_ID LIKE '%' + @p_FATHER_ID + '%' OR @p_FATHER_ID IS NULL OR @p_FATHER_ID = '')
|
69
|
AND (B.BRANCH_CODE LIKE '%' + @p_FATHER_CODE + '%' OR @p_FATHER_CODE IS NULL OR @p_FATHER_CODE = '')
|
70
|
AND (A.BRANCH_CODE LIKE '%' + @p_BRANCH_CODE + '%' OR @p_BRANCH_CODE IS NULL OR @p_BRANCH_CODE = '' OR CD.DEP_CODE LIKE '%' +@p_BRANCH_CODE +'%')
|
71
|
AND (A.BRANCH_NAME LIKE '%' + @p_BRANCH_NAME + '%' OR @p_BRANCH_NAME IS NULL OR @p_BRANCH_NAME = '' OR CD.DEP_NAME LIKE '%' + @p_BRANCH_NAME + '%' OR CD.DEP_CODE LIKE '%' + @p_BRANCH_NAME + '%')
|
72
|
AND (A.REGION_ID LIKE '%' + @p_REGION_ID + '%' OR @p_REGION_ID IS NULL OR @p_REGION_ID = '')
|
73
|
AND (A.BRANCH_TYPE LIKE '%' + @p_BRANCH_TYPE + '%' OR @p_BRANCH_TYPE IS NULL OR @p_BRANCH_TYPE = '')
|
74
|
AND (A.ADDR LIKE '%' + @p_ADDR + '%' OR @p_ADDR IS NULL OR @p_ADDR = '')
|
75
|
AND (A.TEL LIKE '%' + @p_TEL + '%' OR @p_TEL IS NULL OR @p_TEL = '')
|
76
|
AND (A.NOTES LIKE '%' + @p_NOTES + '%' OR @p_NOTES IS NULL OR @p_NOTES = '')
|
77
|
AND (A.RECORD_STATUS LIKE '%' + @p_RECORD_STATUS + '%' OR @p_RECORD_STATUS IS NULL OR @p_RECORD_STATUS = '')
|
78
|
AND (A.MAKER_ID LIKE '%' + @p_MAKER_ID + '%' OR @p_MAKER_ID IS NULL OR @p_MAKER_ID = '')
|
79
|
AND (DATEDIFF(DAY, A.CREATE_DT ,CONVERT(DATETIME, @p_CREATE_DT, 103)) = 0 OR @p_CREATE_DT IS NULL OR @p_CREATE_DT = '')
|
80
|
AND (A.AUTH_STATUS LIKE '%' + @p_AUTH_STATUS + '%' OR @p_AUTH_STATUS IS NULL OR @p_AUTH_STATUS = '')
|
81
|
AND (A.CHECKER_ID LIKE '%' + @p_CHECKER_ID + '%' OR @p_CHECKER_ID IS NULL OR @p_CHECKER_ID = '')
|
82
|
AND (DATEDIFF(DAY,A.APPROVE_DT ,CONVERT(DATETIME, @p_APPROVE_DT, 103)) = 0 OR @p_APPROVE_DT IS NULL OR @p_APPROVE_DT = '')
|
83
|
AND A.RECORD_STATUS = '1'
|
84
|
AND (
|
85
|
(@LOAI_DONVI = 'DVKD' AND A.BRANCH_ID = @p_BRANCH_LOGIN)
|
86
|
OR
|
87
|
(@LOAI_DONVI = 'DVDM')
|
88
|
OR
|
89
|
(@LOAI_DONVI = 'HS' AND ((@p_TYPE_SEARCH = 'FROM' AND A.BRANCH_TYPE = 'HS') OR (@p_TYPE_SEARCH = 'TO' AND A.BRANCH_ID = @p_BRANCH_LOGIN AND CD.DEP_ID = @DEPT_LOGIN)))
|
90
|
)
|
91
|
|
92
|
ORDER BY A.BRANCH_CODE
|
93
|
-- PAGING END
|
94
|
ELSE
|
95
|
-- PAGING BEGIN
|
96
|
|
97
|
SELECT TOP(CONVERT(INT,@P_TOP))A.*, B.BRANCH_CODE AS F_BRANCH_CODE, B.BRANCH_NAME AS F_BRANCH_NAME,CD.DEP_CODE,CD.DEP_NAME,CD.DEP_ID
|
98
|
-- SELECT END
|
99
|
|
100
|
FROM CM_BRANCH A
|
101
|
LEFT JOIN CM_BRANCH B ON A.FATHER_ID = B.BRANCH_ID
|
102
|
LEFT JOIN dbo.CM_DEPARTMENT CD ON CD.BRANCH_ID=A.BRANCH_ID AND A.BRANCH_TYPE='HS'
|
103
|
|
104
|
WHERE 1 = 1
|
105
|
AND (A.BRANCH_ID LIKE '%' + @p_BRANCH_ID + '%' OR @p_BRANCH_ID IS NULL OR @p_BRANCH_ID = '')
|
106
|
-- PHONGNT 17/10/22 THEM DIEU KIEN TIM KIEM PHONGBAN
|
107
|
AND (CD.DEP_ID = @p_DEP_ID OR @p_DEP_ID IS NULL OR @p_DEP_ID = '')
|
108
|
-- END
|
109
|
AND (A.FATHER_ID LIKE '%' + @p_FATHER_ID + '%' OR @p_FATHER_ID IS NULL OR @p_FATHER_ID = '')
|
110
|
AND (A.BRANCH_CODE LIKE '%' + @p_BRANCH_CODE + '%' OR @p_BRANCH_CODE IS NULL OR @p_BRANCH_CODE = '' OR CD.DEP_CODE LIKE '%' +@p_BRANCH_CODE +'%')
|
111
|
AND (B.BRANCH_CODE LIKE '%' + @p_FATHER_CODE + '%' OR @p_FATHER_CODE IS NULL OR @p_FATHER_CODE = '')
|
112
|
AND (A.BRANCH_NAME LIKE '%' + @p_BRANCH_NAME + '%' OR @p_BRANCH_NAME IS NULL OR @p_BRANCH_NAME = '' OR CD.DEP_NAME LIKE '%' + @p_BRANCH_NAME + '%' OR CD.DEP_CODE LIKE '%' + @p_BRANCH_NAME + '%')
|
113
|
AND (A.REGION_ID LIKE '%' + @p_REGION_ID + '%' OR @p_REGION_ID IS NULL OR @p_REGION_ID = '')
|
114
|
AND (A.BRANCH_TYPE LIKE '%' + @p_BRANCH_TYPE + '%' OR @p_BRANCH_TYPE IS NULL OR @p_BRANCH_TYPE = '')
|
115
|
AND (A.ADDR LIKE '%' + @p_ADDR + '%' OR @p_ADDR IS NULL OR @p_ADDR = '')
|
116
|
AND (A.TEL LIKE '%' + @p_TEL + '%' OR @p_TEL IS NULL OR @p_TEL = '')
|
117
|
AND (A.NOTES LIKE '%' + @p_NOTES + '%' OR @p_NOTES IS NULL OR @p_NOTES = '')
|
118
|
AND (A.RECORD_STATUS LIKE '%' + @p_RECORD_STATUS + '%' OR @p_RECORD_STATUS IS NULL OR @p_RECORD_STATUS = '')
|
119
|
AND (A.MAKER_ID LIKE '%' + @p_MAKER_ID + '%' OR @p_MAKER_ID IS NULL OR @p_MAKER_ID = '')
|
120
|
AND (DATEDIFF(DAY,A.CREATE_DT ,CONVERT(DATETIME, @p_CREATE_DT, 103)) = 0 OR @p_CREATE_DT IS NULL OR @p_CREATE_DT = '')
|
121
|
AND (A.AUTH_STATUS LIKE '%' + @p_AUTH_STATUS + '%' OR @p_AUTH_STATUS IS NULL OR @p_AUTH_STATUS = '')
|
122
|
AND (A.CHECKER_ID LIKE '%' + @p_CHECKER_ID + '%' OR @p_CHECKER_ID IS NULL OR @p_CHECKER_ID = '')
|
123
|
AND (DATEDIFF(DAY,A.APPROVE_DT ,CONVERT(DATETIME, @p_APPROVE_DT, 103)) = 0 OR @p_APPROVE_DT IS NULL OR @p_APPROVE_DT = '')
|
124
|
AND A.RECORD_STATUS = '1'
|
125
|
AND (
|
126
|
(@LOAI_DONVI = 'DVKD' AND A.BRANCH_ID = @p_BRANCH_LOGIN)
|
127
|
OR
|
128
|
(@LOAI_DONVI = 'DVDM')
|
129
|
OR
|
130
|
(@LOAI_DONVI = 'HS' AND ((@p_TYPE_SEARCH = 'FROM' AND A.BRANCH_TYPE = 'HS') OR (@p_TYPE_SEARCH = 'TO' AND A.BRANCH_ID = @p_BRANCH_LOGIN AND CD.DEP_ID = @DEPT_LOGIN)))
|
131
|
)
|
132
|
|
133
|
ORDER BY A.BRANCH_CODE
|
134
|
-- PAGING END
|
135
|
|
136
|
END -- PAGING
|
137
|
GO
|