Project

General

Profile

FILE 3.txt

Truong Nguyen Vu, 09/25/2020 03:02 PM

 
1

    
2
 
3
ALTER PROCEDURE [dbo].[PL_REQ_GOOD_Search]  
4
@P_REQDT_TYPE varchar(1)= NULL,  
5
@p_GD_ID VARCHAR(15) = NULL,  
6
@p_GD_CODE varchar(15) = NULL,  
7
@p_GD_NAME nvarchar(200) = NULL,  
8
@p_BRANCH_CODE varchar(15) = NULL,  
9
@p_BRANCH_ID VARCHAR(20) = NULL,  
10
@p_DEP_ID VARCHAR(20) = NULL,  
11
@p_BRANCH_LOGIN varchar(15) = NULL,  
12
@p_USER_LOGIN VARCHAR(20) = NULL,  
13
@P_PLAN_ID NVARCHAR(15) = NULL,  
14
@P_HH_ID VARCHAR(15),  
15
@p_GD_TYPE_ID VARCHAR(20) = NULL,  
16
@p_GD_TYPE_CODE VARCHAR(20)= NULL,  
17
@p_GD_TYPE_NAME NVARCHAR(500)= NULL,  
18
@P_TOP INT = null  
19
AS  
20
BEGIN  
21
DECLARE  
22
@l_QUANTITY numeric(18,0)=0, @l_QUANTITY_EXE decimal(18,0)=0, @l_QUANTITY_REMAIN decimal(18,0)=0,  
23
@l_AMT numeric(18,0)=0, @l_AMT_EXE decimal(18,0)=0, @l_AMT_REMAIN decimal(18,0)=0,@GD_CODE VARCHAR(50),  
24
@BRANCH_TYPE VARCHAR(20),@BRANCH_LOGIN VARCHAR(20),@DEP_LOGIN VARCHAR(20),@ROLE_USER VARCHAR(20),@IS_ALL BIT,@IS_CHUNG BIT  
25
DECLARE @IS_HANHCHINH BIT  
26
SET @IS_HANHCHINH=0  
27
 
28
SET @IS_ALL=0  
29
 
30
DECLARE @DVDM_ID TABLE( DVDM_ID VARCHAR(20))  
31
 
32

    
33
SELECT @BRANCH_LOGIN=TLSUBBRID,@DEP_LOGIN=SECUR_CODE ,@ROLE_USER=RoleName FROM dbo.TL_USER WHERE TLNANME=@p_USER_LOGIN  
34
SET @p_BRANCH_ID=@BRANCH_LOGIN
35
SET @p_DEP_ID=@DEP_LOGIN
36

    
37
IF(@p_BRANCH_CODE IS NOT NULL AND @p_BRANCH_CODE <>'')
38
	SELECT @p_DEP_ID=DEP_ID,@p_BRANCH_ID=BRANCH_ID FROM dbo.CM_DEPARTMENT WHERE DEP_CODE=@p_BRANCH_CODE
39

    
40
IF(@p_BRANCH_ID='' OR @p_BRANCH_ID IS NULL)
41
	SET @p_BRANCH_ID=@BRANCH_LOGIN
42

    
43

    
44
IF(@p_DEP_ID='' OR @p_DEP_ID IS NULL)
45
	SET @p_DEP_ID=@DEP_LOGIN
46
SET @BRANCH_TYPE= (SELECT BRANCH_TYPE FROM dbo.CM_BRANCH WHERE BRANCH_ID=@p_BRANCH_ID)  
47
PRINT @BRANCH_TYPE
48
IF(EXISTS(SELECT ID FROM PL_ROLE_DATA_CONFIG WHERE ROLE_TYPE='PL_MASTER' AND BRANCH_ID=@BRANCH_LOGIN AND DEP_ID=@DEP_LOGIN))  
49
SET @IS_ALL=1  
50
 
51

    
52
 
53
SET @IS_CHUNG=0  
54
 
55
IF(EXISTS(SELECT ID FROM dbo.PL_ROLE_DATA_CONFIG WHERE BRANCH_ID=@p_BRANCH_ID AND DEP_ID=@p_DEP_ID AND ROLE_TYPE='TRADE_USER_ALL'))  
56
BEGIN  
57
 
58
 
59
 
60
IF(EXISTS(  
61
SELECT CC.DVDM_ID FROM dbo.CM_DVDM DM  
62
LEFT JOIN dbo.PL_COSTCENTER CC ON DM.DVDM_ID=CC.DVDM_ID  
63
LEFT JOIN dbo.PL_COSTCENTER_DT CT ON CT.COST_ID=CC.COST_ID  
64
WHERE CT.DEP_ID=@DEP_LOGIN AND CT.BRANCH_ID=@p_BRANCH_ID AND DM.IS_KHOI=1 AND CC.DVDM_ID IN (SELECT CC.DVDM_ID FROM dbo.CM_DVDM DM  
65
LEFT JOIN dbo.PL_COSTCENTER CC ON DM.DVDM_ID=CC.DVDM_ID  
66
LEFT JOIN dbo.PL_COSTCENTER_DT CT ON CT.COST_ID=CC.COST_ID  
67
WHERE CT.DEP_ID=@p_DEP_ID AND CT.BRANCH_ID=@p_BRANCH_ID AND DM.IS_KHOI=1  
68
)))  
69
SET @IS_CHUNG=1  
70
END  
71
 
72
IF(EXISTS(SELECT ID FROM dbo.PL_ROLE_DATA_CONFIG WHERE BRANCH_ID=@BRANCH_LOGIN AND DEP_ID=@DEP_LOGIN AND ROLE_TYPE='HANHCHINH'))  
73
BEGIN  
74
SET @IS_HANHCHINH=1  
75
END  
76
 
77
 
78
---PRINT @IS_CHUNG  
79
 
80
IF(@IS_ALL=1 OR @ROLE_USER='TGD')  
81
BEGIN  
82
INSERT INTO @DVDM_ID  
83
SELECT DVDM_ID FROM dbo.CM_DVDM WHERE IS_DVDM=1  
84
END  
85
ELSE  
86
BEGIN  
87
INSERT INTO @DVDM_ID  
88
SELECT PC.DVDM_ID FROM  
89
dbo.PL_COSTCENTER PC  
90
LEFT JOIN dbo.PL_COSTCENTER_DT PT ON PT.COST_ID=PC.COST_ID  
91
WHERE PT.DEP_ID=@DEP_LOGIN AND PT.BRANCH_ID=@BRANCH_LOGIN AND EXISTS(SELECT DVDM_ID FROM dbo.CM_DVDM WHERE IS_DVDM=1)  
92
 
93
END  
94
 
95
 
96
 PRINT @IS_CHUNG
97
 
98
DECLARE @lstGD TABLE (  
99
GD_ID VARCHAR(20)  
100
)  
101
 
102
DECLARE @lstGD_CODE TABLE (  
103
GD_CODE VARCHAR(20)  
104
)  
105
INSERT INTO @lstGD  
106
SELECT GD_ID FROM dbo.CM_HANGHOA_GOODS WHERE HH_ID=@P_HH_ID  
107
 
108
 
109
IF(@P_HH_ID IS NOT NULL AND @P_HH_ID <>'')  
110
BEGIN  
111
IF(NOT EXISTS(SELECT PM.PLAN_ID FROM dbo.PL_MASTER PM  
112
LEFT JOIN dbo.PL_TRADEDETAIL PT ON PT.PLAN_ID=PM.PLAN_ID  
113
WHERE (PT.GOODS_ID =@p_GD_ID OR EXISTS(SELECT GD_ID FROM @lstGD WHERE [@lstGD].GD_ID=PT.GOODS_ID))  
114
AND PM.YEAR = YEAR(GETDATE())  
115
AND (  
116
(  
117
@BRANCH_TYPE='HS' AND PM.BRANCH_ID =@p_BRANCH_ID AND PM.DEPT_ID=@p_DEP_ID  
118
AND( @IS_CHUNG=1 OR @IS_HANHCHINH=1 OR @IS_ALL=1 OR ((@p_DEP_ID = @DEP_LOGIN) OR (@p_DEP_ID <> @DEP_LOGIN AND (PM.COST_ID IN (SELECT DVDM_ID FROM @DVDM_ID)))))   
119
)  
120
OR  
121
(@BRANCH_TYPE='CN' AND PM.BRANCH_ID =@p_BRANCH_ID AND ((@p_BRANCH_ID=@BRANCH_LOGIN) OR (@p_BRANCH_ID <> @BRANCH_LOGIN AND PM.BRANCH_ID IN (SELECT BRANCH_ID FROM [dbo].[CM_BRANCH_GETCHILDID](@BRANCH_LOGIN) )) ))  
122
OR  
123
(@BRANCH_TYPE='PGD' AND PM.BRANCH_ID =@p_BRANCH_ID )  
124
)
125
OR
126
( 
127
	EXISTS (SELECT * FROM dbo.PL_ROLE_DATA_CONFIG WHERE ROLE_TYPE='TRADE_USER_VIEW' AND BRANCH_ID=@p_USER_LOGIN AND DEP_ID=PT.GOODS_ID)
128
)
129
)  
130
 
131
)  
132
BEGIN  
133
SET @P_REQDT_TYPE='O'  
134
INSERT INTO @lstGD_CODE  
135
SELECT REPLACE(GD_CODE,'.I.','.O.') FROM dbo.CM_GOODS WHERE GD_ID IN (SELECT GD_ID FROM @lstGD)  
136
END  
137
END  
138
 
139
 
140
 
141
 PRINT @IS_ALL
142
 PRINT @IS_CHUNG
143
 PRINT @IS_HANHCHINH
144

    
145
IF(@P_REQDT_TYPE='I')  
146
BEGIN  
147
IF(@P_PLAN_ID IS NOT NULL AND @P_PLAN_ID <>'')  
148
BEGIN  
149
 
150
SELECT PM.PLAN_ID,PM.PLAN_CODE,DT.TRADE_ID,DT.GOODS_ID,CG.GD_CODE,CG.GD_NAME,PM.BRANCH_ID,PM.DEPT_ID,  
151
ISNULL(DT.QUANTITY,0) AS QUANTITY,  
152
ISNULL(DT.QUANTITY_EXE,0) AS QUANTITY_EXE,  
153
ISNULL(DT.QUANTITY_ETM,0) AS QUANTITY_ETM,  
154
ISNULL(DT.QUANTITY,0)- ISNULL(DT.QUANTITY_EXE,0) AS QUANTITY_REMAIN,  
155
ISNULL(DT.QUANTITY,0)-ISNULL(DT.QUANTITY_ETM,0) AS QUANTITY_REMAIN_ETM,  
156
ISNULL( DT.AMT_APP,0) + ISNULL( DT.AMT_RECEIVE_TF,0) AS AMT_APP,  
157
ISNULL( DT.AMT_EXE,0) AS AMT_EXE,  
158
ISNULL( DT.AMT_ETM,0) AS AMT_ETM,  
159
ISNULL( DT.AMT_TF,0) AS AMT_TF,  
160
ISNULL( DT.AMT_RECEIVE_TF,0) AS AMT_RECEIVE_TF,  
161
ISNULL(DT.AMT_APP,0) + ISNULL( DT.AMT_RECEIVE_TF,0)- ISNULL( DT.AMT_TF,0)- ISNULL(DT.AMT_EXE,0) AS AMT_REMAIN,  
162
ISNULL(DT.AMT_APP,0) + ISNULL( DT.AMT_RECEIVE_TF,0)- ISNULL( DT.AMT_TF,0)-ISNULL(DT.AMT_ETM,0) AS AMT_REMAIN_ETM,  
163
CB.BRANCH_CODE,CB.BRANCH_NAME,'I' AS REQDT_TYPE,  
164
DT.NOTES,PT.PLAN_TYPE_CODE,PT.PLAN_TYPE_NAME,CM.DVDM_ID AS COST_ID,CM.DVDM_CODE AS COST_CODE,CM.DVDM_NAME AS COST_NAME,CK.DVDM_CODE AS KHOI_CODE,CK.DVDM_ID AS KHOI_ID,CK.DVDM_NAME AS KHOI_NAME,  
165
DM.DVDM_ID,DM.DVDM_CODE,DM.DVDM_NAME,CD.DEP_CODE,CD.DEP_NAME,GT.GD_TYPE_NAME,GT.GD_TYPE_CODE,GT.GD_TYPE_ID  
166
FROM dbo.PL_MASTER PM  
167
LEFT JOIN dbo.PL_TRADEDETAIL DT ON DT.PLAN_ID=PM.PLAN_ID  
168
LEFT JOIN dbo.CM_PLAN_TYPE PT ON PT.PLAN_TYPE_ID=PM.PLAN_TYPE_ID  
169
 
170
LEFT JOIN dbo.CM_GOODS CG ON CG.GD_ID=DT.GOODS_ID  
171
LEFT JOIN dbo.CM_GOOD_DVDM CGDM ON CGDM.GD_ID=CG.GD_ID  
172
LEFT JOIN dbo.CM_GOODSTYPE GT ON CG.GD_CODE LIKE '%.' + GT.GD_TYPE_CODE +'.%'  
173
LEFT JOIN dbo.CM_BRANCH CB ON CB.BRANCH_ID=PM.BRANCH_ID  
174
LEFT JOIN dbo.CM_DEPARTMENT CD ON CD.DEP_ID=PM.DEPT_ID  
175
 
176
LEFT JOIN dbo.CM_DVDM DM ON DM.DVDM_ID=PM.COST_ID  
177
LEFT JOIN dbo.CM_DVDM CM ON CM.DVDM_ID=DM.DVDM_ID  
178
LEFT JOIN dbo.CM_DVDM_KHOI DMKH ON DMKH.DVDM_ID = DM.DVDM_ID
179
LEFT JOIN dbo.CM_DVDM CK ON CK.DVDM_ID=DMKH.KHOI_ID  
180
WHERE (1=1)  
181
AND (CG.GD_NAME LIKE '%' + @p_GD_NAME + '%' OR @p_GD_NAME IS NULL OR @p_GD_NAME ='')  
182
AND (CG.GD_CODE LIKE '%' + @p_GD_CODE + '%' OR @p_GD_CODE IS NULL OR @p_GD_CODE ='')  
183
--AND (CB.BRANCH_CODE LIKE '%' + @p_BRANCH_CODE +'%' OR @p_BRANCH_CODE IS NULL OR @p_BRANCH_CODE ='')  
184
--AND (PM.BRANCH_ID IN (SELECT BRANCH_ID FROM [dbo].[CM_BRANCH_GETCHILDID](@p_BRANCH_LOGIN)))  
185
--AND(PM.BRANCH_ID= @p_BRANCH_ID OR @p_BRANCH_ID IS NULL OR @p_BRANCH_ID='')  
186
AND (PM.PLAN_ID LIKE '%' + @P_PLAN_ID+'%' OR @P_PLAN_ID IS NULL OR @P_PLAN_ID='' )  
187
AND (DT.GOODS_ID = @p_GD_ID OR @p_GD_ID IS NULL OR @p_GD_ID ='')  
188
AND (EXISTS(SELECT GD_ID FROM @lstGD WHERE [@lstGD].GD_ID=DT.GOODS_ID) OR @P_HH_ID ='' OR @P_HH_ID IS NULL)  
189
AND PM.YEAR = YEAR(GETDATE())  
190
 
191
AND (GT.GD_TYPE_ID LIKE '%' + @p_GD_TYPE_ID + '%' OR @p_GD_TYPE_ID IS NULL OR @p_GD_TYPE_ID ='')  
192
AND (GT.GD_TYPE_CODE LIKE '%' + @p_GD_TYPE_CODE + '%' OR @p_GD_TYPE_CODE IS NULL OR @p_GD_TYPE_CODE ='')  
193
AND (GT.GD_TYPE_NAME LIKE N'%' + @p_GD_TYPE_NAME + N'%' OR @p_GD_TYPE_NAME IS NULL OR @p_GD_TYPE_NAME ='') 
194
AND DT.RECORD_STATUS='1' 
195
END  
196
ELSE  
197
BEGIN  
198
SELECT PM.PLAN_ID,PM.PLAN_CODE,DT.TRADE_ID,DT.GOODS_ID,CG.GD_CODE,CG.GD_NAME,PM.BRANCH_ID,PM.DEPT_ID,  
199
ISNULL(DT.QUANTITY,0) AS QUANTITY,  
200
ISNULL(DT.QUANTITY_EXE,0) AS QUANTITY_EXE,  
201
ISNULL(DT.QUANTITY_ETM,0) AS QUANTITY_ETM,  
202
ISNULL(DT.QUANTITY,0)- ISNULL(DT.QUANTITY_EXE,0) AS QUANTITY_REMAIN,  
203
ISNULL(DT.QUANTITY,0)-ISNULL(DT.QUANTITY_ETM,0) AS QUANTITY_REMAIN_ETM,  
204
ISNULL( DT.AMT_APP,0)  + ISNULL( DT.AMT_RECEIVE_TF,0) AS AMT_APP,  
205
ISNULL( DT.AMT_EXE,0) AS AMT_EXE,  
206
ISNULL( DT.AMT_ETM,0) AS AMT_ETM,  
207
ISNULL( DT.AMT_TF,0) AS AMT_TF,  
208
ISNULL( DT.AMT_RECEIVE_TF,0) AS AMT_RECEIVE_TF,  
209
ISNULL(DT.AMT_APP,0) + ISNULL( DT.AMT_RECEIVE_TF,0)- ISNULL( DT.AMT_TF,0)- ISNULL(DT.AMT_EXE,0) AS AMT_REMAIN,  
210
ISNULL(DT.AMT_APP,0) + ISNULL( DT.AMT_RECEIVE_TF,0)- ISNULL( DT.AMT_TF,0)-ISNULL(DT.AMT_ETM,0) AS AMT_REMAIN_ETM,  
211
CB.BRANCH_CODE,CB.BRANCH_NAME,'I' AS REQDT_TYPE,  
212
DT.NOTES,PT.PLAN_TYPE_CODE,PT.PLAN_TYPE_NAME,CM.DVDM_ID AS COST_ID,CM.DVDM_CODE AS COST_CODE,CM.DVDM_NAME AS COST_NAME,CK.DVDM_CODE AS KHOI_CODE,CK.DVDM_ID AS KHOI_ID,CK.DVDM_NAME AS KHOI_NAME,  
213
DM.DVDM_ID,DM.DVDM_CODE,DM.DVDM_NAME,CD.DEP_CODE,CD.DEP_NAME,GT.GD_TYPE_NAME,GT.GD_TYPE_CODE,GT.GD_TYPE_ID  
214
FROM dbo.PL_MASTER PM  
215
LEFT JOIN dbo.PL_TRADEDETAIL DT ON DT.PLAN_ID=PM.PLAN_ID  
216
LEFT JOIN dbo.CM_PLAN_TYPE PT ON PT.PLAN_TYPE_ID=PM.PLAN_TYPE_ID  
217
 
218
LEFT JOIN dbo.CM_GOODS CG ON CG.GD_ID=DT.GOODS_ID  
219
LEFT JOIN dbo.CM_GOOD_DVDM CGDM ON CGDM.GD_ID=CG.GD_ID  
220
LEFT JOIN dbo.CM_GOODSTYPE GT ON CG.GD_CODE LIKE '%.' + GT.GD_TYPE_CODE +'.%'  
221
LEFT JOIN dbo.CM_BRANCH CB ON CB.BRANCH_ID=PM.BRANCH_ID  
222
LEFT JOIN dbo.CM_DEPARTMENT CD ON CD.DEP_ID=PM.DEPT_ID  
223
 
224
LEFT JOIN dbo.CM_DVDM DM ON DM.DVDM_ID=PM.COST_ID  
225
LEFT JOIN dbo.CM_DVDM CM ON CM.DVDM_ID=DM.DVDM_ID  
226
LEFT JOIN dbo.CM_DVDM_KHOI DMKH ON DMKH.DVDM_ID = DM.DVDM_ID
227
LEFT JOIN dbo.CM_DVDM CK ON CK.DVDM_ID=DMKH.KHOI_ID  
228
WHERE (1=1)  
229
AND (CG.GD_NAME LIKE '%' + @p_GD_NAME + '%' OR @p_GD_NAME IS NULL OR @p_GD_NAME ='')  
230
AND (CG.GD_CODE LIKE '%' + @p_GD_CODE + '%' OR @p_GD_CODE IS NULL OR @p_GD_CODE ='')  
231
--AND (CB.BRANCH_CODE LIKE '%' + @p_BRANCH_CODE +'%' OR @p_BRANCH_CODE IS NULL OR @p_BRANCH_CODE ='')  
232
--AND (PM.BRANCH_ID IN (SELECT BRANCH_ID FROM [dbo].[CM_BRANCH_GETCHILDID](@p_BRANCH_LOGIN)))  
233
--AND(PM.BRANCH_ID= @p_BRANCH_ID OR @p_BRANCH_ID IS NULL OR @p_BRANCH_ID='')  
234
AND (PM.PLAN_ID LIKE '%' + @P_PLAN_ID+'%' OR @P_PLAN_ID IS NULL OR @P_PLAN_ID='' )  
235
AND (DT.GOODS_ID = @p_GD_ID OR @p_GD_ID IS NULL OR @p_GD_ID ='')  
236
AND (EXISTS(SELECT GD_ID FROM @lstGD WHERE [@lstGD].GD_ID=DT.GOODS_ID) OR @P_HH_ID ='' OR @P_HH_ID IS NULL)  
237
AND  (  
238
(  
239
@BRANCH_TYPE='HS' AND PM.BRANCH_ID =@p_BRANCH_ID AND PM.DEPT_ID=@p_DEP_ID  
240
AND( @IS_CHUNG=1 OR @IS_HANHCHINH=1 OR @IS_ALL=1 OR ((@p_DEP_ID = @DEP_LOGIN) OR (@p_DEP_ID <> @DEP_LOGIN AND (PM.COST_ID IN (SELECT DVDM_ID FROM @DVDM_ID)))))   
241
)  
242
OR  
243
(@BRANCH_TYPE='CN' AND PM.BRANCH_ID =@p_BRANCH_ID AND ((@p_BRANCH_ID=@BRANCH_LOGIN) OR (@p_BRANCH_ID <> @BRANCH_LOGIN AND PM.BRANCH_ID IN (SELECT BRANCH_ID FROM [dbo].[CM_BRANCH_GETCHILDID](@BRANCH_LOGIN) )) ))  
244
OR  
245
(@BRANCH_TYPE='PGD' AND PM.BRANCH_ID =@p_BRANCH_ID )  
246
OR
247
( 
248
	EXISTS (SELECT * FROM dbo.PL_ROLE_DATA_CONFIG WHERE ROLE_TYPE='TRADE_USER_VIEW' AND BRANCH_ID=@p_USER_LOGIN AND DEP_ID=DT.GOODS_ID)
249
)
250
)  
251
  
252
AND PM.YEAR = YEAR(GETDATE())  
253
 
254
AND (GT.GD_TYPE_ID LIKE '%' + @p_GD_TYPE_ID + '%' OR @p_GD_TYPE_ID IS NULL OR @p_GD_TYPE_ID ='')  
255
AND (GT.GD_TYPE_CODE LIKE '%' + @p_GD_TYPE_CODE + '%' OR @p_GD_TYPE_CODE IS NULL OR @p_GD_TYPE_CODE ='')  
256
AND (GT.GD_TYPE_NAME LIKE N'%' + @p_GD_TYPE_NAME + N'%' OR @p_GD_TYPE_NAME IS NULL OR @p_GD_TYPE_NAME ='')  
257
AND DT.RECORD_STATUS='1' 
258
END  
259
 
260
END  
261
ELSE  
262
BEGIN  
263
SELECT '' AS PLAN_ID,'' AS PLAN_CODE,'' AS TRADE_ID, CG.GD_ID AS GOODS_ID, CG.GD_CODE ,CG.GD_NAME ,'' AS BRANCH_ID,'' AS DEPT_ID,  
264
@l_QUANTITY AS QUANTITY,  
265
@l_QUANTITY_EXE AS QUANTITY_EXE,  
266
@l_QUANTITY_EXE AS QUANTITY_ETM,  
267
@l_QUANTITY_REMAIN AS QUANTITY_REMAIN,  
268
@l_QUANTITY_REMAIN AS QUANTITY_REMAIN_ETM,  
269
@l_AMT AS AMT_APP,  
270
@l_AMT_EXE AS AMT_EXE,  
271
@l_AMT_EXE AS AMT_ETM,  
272
@l_AMT_EXE AS AMT_TF,  
273
@l_AMT_EXE AS AMT_RECEIVE_TF,  
274
@l_AMT_REMAIN AS AMT_REMAIN,  
275
@l_AMT_REMAIN AS AMT_REMAIN_ETM,  
276
'' AS BRANCH_CODE,  
277
N'Ngoài kế hoạch' AS BRANCH_NAME,  
278
'O' AS REQDT_TYPE,  
279
'' AS NOTES  
280
,'' AS PLAN_TYPE_CODE,'' AS PLAN_TYPE_NAME,CM.DVDM_ID AS COST_ID,CM.DVDM_CODE AS COST_CODE,CM.DVDM_NAME AS COST_NAME,CK.DVDM_CODE AS KHOI_CODE,CK.DVDM_ID AS KHOI_ID,CK.DVDM_NAME AS KHOI_NAME,  
281
DM.DVDM_ID,DM.DVDM_CODE,DM.DVDM_NAME,'' DEP_CODE,'' DEP_NAME,GT.GD_TYPE_NAME,GT.GD_TYPE_CODE,GT.GD_TYPE_ID  
282
FROM dbo.CM_GOODS CG  
283
LEFT JOIN dbo.CM_GOODSTYPE GT ON CG.GD_CODE LIKE '%.' + GT.GD_TYPE_CODE +'.%'  
284
LEFT JOIN dbo.CM_GOOD_DVDM CGDM ON CGDM.GD_ID=CG.GD_ID  
285
LEFT JOIN dbo.CM_DVDM DM ON DM.DVDM_ID=CGDM.DVDM_ID  
286
LEFT JOIN dbo.CM_DVDM CM ON CM.DVDM_ID=CGDM.DVCM_ID  
287
LEFT JOIN dbo.CM_DVDM CK ON CK.DVDM_ID=CGDM.KHOI_ID  
288
 
289
 
290
 
291
WHERE (1=1)  
292
AND (CG.GD_NAME LIKE '%' + @p_GD_NAME + '%' OR @p_GD_NAME IS NULL OR @p_GD_NAME ='')  
293
AND (CG.GD_CODE LIKE '%' + @p_GD_CODE + '%' OR @p_GD_CODE IS NULL OR @p_GD_CODE ='')  
294
AND CG.GD_CODE LIKE '%.O.%'  
295
AND (EXISTS(SELECT GD_CODE FROM @lstGD_CODE WHERE [@lstGD_CODE].GD_CODE=CG.GD_CODE ) OR @P_HH_ID ='' OR @P_HH_ID IS NULL)  
296
AND (GT.GD_TYPE_ID LIKE '%' + @p_GD_TYPE_ID + '%' OR @p_GD_TYPE_ID IS NULL OR @p_GD_TYPE_ID ='')  
297
AND (GT.GD_TYPE_CODE LIKE '%' + @p_GD_TYPE_CODE + '%' OR @p_GD_TYPE_CODE IS NULL OR @p_GD_TYPE_CODE ='')  
298
AND (GT.GD_TYPE_NAME LIKE N'%' + @p_GD_TYPE_NAME + N'%' OR @p_GD_TYPE_NAME IS NULL OR @p_GD_TYPE_NAME ='')  
299

    
300
END  
301
  
302

    
303
END