Project

General

Profile

dbo.CM_BRANCH_DEP_Search_v2.txt

Luc Tran Van, 10/18/2022 03:07 PM

 
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 OR CD.DEP_ID = @p_DEP_ID))))
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 OR CD.DEP_ID = @p_DEP_ID))))
131
		)
132

    
133
		ORDER BY A.BRANCH_CODE
134
			-- PAGING END
135

    
136
END -- PAGING