1
|
|
2
|
ALTER PROCEDURE [dbo].[PL_REQUEST_DOC_DT_ById]
|
3
|
@P_REQ_ID varchar(15),
|
4
|
@P_TYPE VARCHAR(20),
|
5
|
@P_USER_LOGIN VARCHAR(20)
|
6
|
AS
|
7
|
|
8
|
|
9
|
DECLARE @listTRADE TABLE
|
10
|
(
|
11
|
GOODS_ID VARCHAR(20),
|
12
|
TRADE_ID VARCHAR(20),
|
13
|
PLAN_ID VARCHAR(20),
|
14
|
AMT_APP DECIMAL(18,2),
|
15
|
AMT_EXE DECIMAL (18,2),
|
16
|
AMT_ETM DECIMAL (18,2),
|
17
|
AMT_TF DECIMAL (18,2),
|
18
|
AMT_RECEIVE_TF DECIMAL (18,2),
|
19
|
NOTES NVARCHAR(1000)
|
20
|
)
|
21
|
|
22
|
IF(EXISTS(SELECT * FROM dbo.PL_REQUEST_DOC WHERE REQ_ID=@P_REQ_ID AND PROCESS_ID='APPROVE'))
|
23
|
BEGIN
|
24
|
IF(EXISTS(SELECT * FROM dbo.PL_TRADEDETAIL_HIST WHERE REQ_ID=@P_REQ_ID))
|
25
|
BEGIN
|
26
|
INSERT INTO @listTRADE
|
27
|
( GOODS_ID,TRADE_ID,PLAN_ID,AMT_APP,AMT_EXE,AMT_ETM,AMT_TF,AMT_RECEIVE_TF, NOTES)
|
28
|
SELECT GOODS_ID,TRADE_ID,PLAN_ID,AMT_APP,AMT_EXE,AMT_ETM,AMT_TF,AMT_RECEIVE_TF, NOTES FROM dbo.PL_TRADEDETAIL_HIST WHERE REQ_ID=@P_REQ_ID
|
29
|
END
|
30
|
ELSE
|
31
|
BEGIN
|
32
|
INSERT INTO @listTRADE
|
33
|
( GOODS_ID,TRADE_ID,PLAN_ID,AMT_APP,AMT_EXE,AMT_ETM,AMT_TF,AMT_RECEIVE_TF, NOTES)
|
34
|
SELECT PT.GOODS_ID,PT.TRADE_ID,PT.PLAN_ID,PT.AMT_APP,PT.AMT_EXE,PT.AMT_ETM-PLDT.TOTAL_AMT,PT.AMT_TF-PLFT.TOTAL_AMT,PT.AMT_RECEIVE_TF-PLTT.TOTAL_AMT, PT.NOTES FROM dbo.PL_TRADEDETAIL PT
|
35
|
LEFT JOIN
|
36
|
(
|
37
|
SELECT TRADE_ID, SUM(TOTAL_AMT) TOTAL_AMT FROM
|
38
|
dbo.PL_REQUEST_DOC_DT WHERE REQ_ID=@P_REQ_ID
|
39
|
GROUP BY TRADE_ID
|
40
|
) PLDT ON PLDT.TRADE_ID = PT.TRADE_ID
|
41
|
LEFT JOIN
|
42
|
(
|
43
|
SELECT FR_TRADE_ID, SUM(TOTAL_AMT) TOTAL_AMT FROM
|
44
|
dbo.PL_REQUEST_TRANSFER WHERE REQ_DOC_ID=@P_REQ_ID
|
45
|
GROUP BY FR_TRADE_ID
|
46
|
) PLFT ON PLFT.FR_TRADE_ID = PT.TRADE_ID
|
47
|
|
48
|
LEFT JOIN
|
49
|
(
|
50
|
SELECT TO_TRADE_ID, SUM(TOTAL_AMT) TOTAL_AMT FROM
|
51
|
dbo.PL_REQUEST_TRANSFER WHERE REQ_DOC_ID=@P_REQ_ID
|
52
|
GROUP BY TO_TRADE_ID
|
53
|
) PLTT ON PLTT.TO_TRADE_ID = PT.TRADE_ID
|
54
|
WHERE (PT.TRADE_ID IN (SELECT TRADE_ID FROM dbo.PL_REQUEST_DOC_DT WHERE REQ_ID=@p_REQ_ID) OR PT.TRADE_ID IN (SELECT FR_TRADE_ID FROM dbo.PL_REQUEST_TRANSFER WHERE REQ_DOC_ID=@p_REQ_ID))
|
55
|
END
|
56
|
END
|
57
|
ELSE
|
58
|
BEGIN
|
59
|
INSERT INTO @listTRADE
|
60
|
( GOODS_ID,TRADE_ID,PLAN_ID,AMT_APP,AMT_EXE,AMT_ETM,AMT_TF,AMT_RECEIVE_TF, NOTES)
|
61
|
SELECT GOODS_ID,TRADE_ID,PLAN_ID,AMT_APP,AMT_EXE,AMT_ETM,AMT_TF,AMT_RECEIVE_TF, NOTES FROM dbo.PL_TRADEDETAIL WHERE (TRADE_ID IN (SELECT TRADE_ID FROM dbo.PL_REQUEST_DOC_DT WHERE REQ_ID=@p_REQ_ID) OR TRADE_ID IN (SELECT FR_TRADE_ID FROM dbo.PL_REQUEST_TRANSFER WHERE REQ_DOC_ID=@p_REQ_ID))
|
62
|
END
|
63
|
|
64
|
DECLARE @DEP_ID VARCHAR(15),@BRANCH_ID VARCHAR(15),@ROLE VARCHAR(15),@IS_ALL BIT
|
65
|
|
66
|
|
67
|
SET @IS_ALL=0
|
68
|
|
69
|
DECLARE
|
70
|
@COST_ID TABLE (
|
71
|
COST_ID VARCHAR(15)
|
72
|
)
|
73
|
|
74
|
DECLARE @DVDM_ID TABLE (
|
75
|
DVDM_ID VARCHAR(15)
|
76
|
)
|
77
|
|
78
|
|
79
|
SET @DEP_ID=(SELECT SECUR_CODE FROM dbo.TL_USER WHERE TLNANME=@P_USER_LOGIN)
|
80
|
|
81
|
SET @BRANCH_ID=(SELECT TLSUBBRID FROM dbo.TL_USER WHERE TLNANME=@P_USER_LOGIN)
|
82
|
IF(EXISTS(SELECT ID FROM PL_ROLE_DATA_CONFIG WHERE ROLE_TYPE='PL_MASTER' AND BRANCH_ID=@BRANCH_ID AND DEP_ID=@DEP_ID))
|
83
|
SET @IS_ALL=1
|
84
|
SET @ROLE=(SELECT RoleName FROM dbo.TL_USER WHERE TLNANME=@P_USER_LOGIN)
|
85
|
|
86
|
INSERT INTO @COST_ID
|
87
|
SELECT COST_ID FROM dbo.PL_COSTCENTER_DT WHERE DEP_ID=@DEP_ID AND BRANCH_ID=@BRANCH_ID
|
88
|
|
89
|
INSERT INTO @DVDM_ID
|
90
|
SELECT DVDM_ID FROM dbo.PL_COSTCENTER WHERE COST_ID IN (SELECT COST_ID FROM @COST_ID) GROUP BY DVDM_ID
|
91
|
|
92
|
|
93
|
|
94
|
IF(@P_TYPE='DVKD')
|
95
|
BEGIN
|
96
|
|
97
|
SELECT A.REQDT_ID,A.NAME,A.GOODS_ID,A.QUANTITY,A.TOTAL_AMT,A.PRICE,A.TRADE_ID,A.PLAN_ID,PL.NOTES,A.DESCRIPTION,A.HANGHOA_ID,HH.HH_CODE,HH.HH_NAME,A.CURRENCY,A.EXCHANGE_RATE,A.TAXES,
|
98
|
B.GD_CODE, B.GD_ID, B.GD_NAME, C.UNIT_CODE, C.UNIT_ID, A.UNIT_NAME,
|
99
|
|
100
|
ISNULL(PL.AMT_APP,0) AS AMT_APP,
|
101
|
ISNULL(PL.AMT_EXE,0) AS AMT_EXE,
|
102
|
ISNULL(PL.AMT_ETM,0) AS AMT_ETM,
|
103
|
ISNULL(PL.AMT_TF,0) AS AMT_TF,
|
104
|
ISNULL(PL.AMT_RECEIVE_TF,0) AS AMT_RECEIVE_TF,
|
105
|
ISNULL(PL.AMT_APP,0) + ISNULL(PL.AMT_RECEIVE_TF,0)-ISNULL(PL.AMT_TF,0) - ISNULL(PL.AMT_EXE,0) AS AMT_REMAIN,
|
106
|
ISNULL(PL.AMT_APP,0) + ISNULL(PL.AMT_RECEIVE_TF,0)-ISNULL(PL.AMT_TF,0)- ISNULL(PL.AMT_ETM,0) AS AMT_REMAIN_ETM,
|
107
|
ISNULL(PL.AMT_APP,0) + ISNULL(PL.AMT_RECEIVE_TF,0)-ISNULL(PL.AMT_TF,0)- ISNULL(PL.AMT_ETM,0)-ISNULL((SELECT SUM(Temp.TOTAL_AMT) AS TOTAL_AMT FROM dbo.PL_REQUEST_DOC_DT Temp WHERE Temp.REQ_ID=@P_REQ_ID AND Temp.TRADE_ID=A.TRADE_ID
|
108
|
AND EXISTS(SELECT REQ_ID FROM dbo.PL_REQUEST_DOC WHERE REQ_ID=@P_REQ_ID AND PROCESS_ID <>'APPROVE')
|
109
|
GROUP BY Temp.TRADE_ID),0)
|
110
|
AS AMT_REMAIN_REQ,
|
111
|
A.REQDT_TYPE,A.KHOI_ID,CK.DVDM_CODE AS KHOI_CODE,CK.DVDM_NAME AS KHOI_NAME,
|
112
|
A.DVDM_ID,DM.DVDM_CODE,DM.DVDM_NAME,A.TRADE_TYPE,A.SUP_ID,CS.SUP_NAME,CS.SUP_CODE,GT.GD_TYPE_NAME,GT.GD_TYPE_CODE,GT.GD_TYPE_ID,A.[NAME] AS REASON_CDT
|
113
|
FROM PL_REQUEST_DOC_DT A
|
114
|
LEFT JOIN @listTRADE PL ON A.TRADE_ID=PL.TRADE_ID
|
115
|
LEFT JOIN CM_GOODS B On A.GOODS_ID=B.GD_ID
|
116
|
LEFT JOIN dbo.CM_GOODSTYPE GT ON B.GD_CODE LIKE '%.' + GT.GD_TYPE_CODE +'.%'
|
117
|
LEFT JOIN CM_UNIT C On A.UNIT_ID=C.UNIT_ID
|
118
|
|
119
|
LEFT JOIN dbo.CM_DVDM DM ON DM.DVDM_ID=A.DVDM_ID
|
120
|
LEFT JOIN dbo.CM_DVDM CK ON CK.DVDM_ID=A.KHOI_ID
|
121
|
LEFT JOIN dbo.CM_HANGHOA HH ON HH.HH_ID=A.HANGHOA_ID
|
122
|
LEFT JOIN dbo.CM_SUPPLIER CS ON CS.SUP_ID=A.SUP_ID
|
123
|
WHERE A.REQ_ID=@P_REQ_ID
|
124
|
END
|
125
|
ELSE IF(@P_TYPE='PDTT')
|
126
|
BEGIN
|
127
|
|
128
|
SELECT A.REQDT_ID,A.NAME,A.GOODS_ID,A.QUANTITY,A.TOTAL_AMT,A.PRICE,A.TRADE_ID,A.PLAN_ID,PL.NOTES,A.DESCRIPTION,A.HANGHOA_ID,HH.HH_CODE,HH.HH_NAME,A.CURRENCY,A.EXCHANGE_RATE,A.TAXES,
|
129
|
B.GD_CODE, B.GD_ID, B.GD_NAME, C.UNIT_CODE, C.UNIT_ID, A.UNIT_NAME,
|
130
|
|
131
|
ISNULL(PL.AMT_APP,0) AS AMT_APP,
|
132
|
ISNULL(PL.AMT_EXE,0) AS AMT_EXE,
|
133
|
ISNULL(PL.AMT_ETM,0) AS AMT_ETM,
|
134
|
ISNULL(PL.AMT_TF,0) AS AMT_TF,
|
135
|
ISNULL(PL.AMT_RECEIVE_TF,0) AS AMT_RECEIVE_TF,
|
136
|
ISNULL(PL.AMT_APP,0) + ISNULL(PL.AMT_RECEIVE_TF,0)-ISNULL(PL.AMT_TF,0) - ISNULL(PL.AMT_EXE,0) AS AMT_REMAIN,
|
137
|
ISNULL(PL.AMT_APP,0) + ISNULL(PL.AMT_RECEIVE_TF,0)-ISNULL(PL.AMT_TF,0)- ISNULL(PL.AMT_ETM,0) AS AMT_REMAIN_ETM,
|
138
|
ISNULL(PL.AMT_APP,0) + ISNULL(PL.AMT_RECEIVE_TF,0)-ISNULL(PL.AMT_TF,0)- ISNULL(PL.AMT_ETM,0)-ISNULL((SELECT SUM(Temp.TOTAL_AMT) AS TOTAL_AMT FROM dbo.PL_REQUEST_DOC_DT Temp WHERE Temp.REQ_ID=@P_REQ_ID AND Temp.TRADE_ID=A.TRADE_ID
|
139
|
AND EXISTS(SELECT REQ_ID FROM dbo.PL_REQUEST_DOC WHERE REQ_ID=@P_REQ_ID AND PROCESS_ID <>'APPROVE')
|
140
|
GROUP BY Temp.TRADE_ID),0)
|
141
|
AS AMT_REMAIN_REQ,
|
142
|
A.REQDT_TYPE,A.KHOI_ID,CK.DVDM_CODE AS KHOI_CODE,CK.DVDM_NAME AS KHOI_NAME,
|
143
|
A.DVDM_ID,DM.DVDM_CODE,DM.DVDM_NAME,A.TRADE_TYPE,A.SUP_ID,CS.SUP_NAME,CS.SUP_CODE,GT.GD_TYPE_NAME,GT.GD_TYPE_CODE,GT.GD_TYPE_ID,A.[NAME] AS REASON_CDT
|
144
|
FROM PL_REQUEST_DOC_DT A
|
145
|
LEFT JOIN @listTRADE PL ON A.TRADE_ID=PL.TRADE_ID
|
146
|
LEFT JOIN CM_GOODS B On A.GOODS_ID=B.GD_ID
|
147
|
LEFT JOIN dbo.CM_GOODSTYPE GT ON B.GD_CODE LIKE '%.' + GT.GD_TYPE_CODE +'.%'
|
148
|
LEFT JOIN CM_UNIT C On A.UNIT_ID=C.UNIT_ID
|
149
|
|
150
|
LEFT JOIN dbo.CM_DVDM DM ON DM.DVDM_ID=A.DVDM_ID
|
151
|
LEFT JOIN dbo.CM_DVDM CK ON CK.DVDM_ID=A.KHOI_ID
|
152
|
LEFT JOIN dbo.CM_HANGHOA HH ON HH.HH_ID=A.HANGHOA_ID
|
153
|
LEFT JOIN dbo.CM_SUPPLIER CS ON CS.SUP_ID=A.SUP_ID
|
154
|
LEFT JOIN dbo.PL_REQUEST_TRANSFER PLT ON PLT.REQ_DOC_ID=A.REQ_ID AND PLT.TO_GOOD_ID=A.GOODS_ID
|
155
|
WHERE A.REQ_ID=@P_REQ_ID
|
156
|
--AND (@ROLE='TGD' OR @IS_ALL=1 OR @ROLE='HDQT' OR EXISTS(SELECT * FROM @DVDM_ID WHERE [@DVDM_ID].DVDM_ID=A.DVDM_ID OR [@DVDM_ID].DVDM_ID=A.KHOI_ID ) OR EXISTS(SELECT * FROM @DVDM_ID WHERE [@DVDM_ID].DVDM_ID=PLT.FR_DVDM_ID OR [@DVDM_ID].DVDM_ID=PLT.FR_KHOI_ID ))
|
157
|
END
|
158
|
ELSE IF(@P_TYPE='XLTT')
|
159
|
BEGIN
|
160
|
|
161
|
SELECT A.REQDT_ID,A.NAME,A.GOODS_ID,A.QUANTITY,A.TOTAL_AMT,A.PRICE,A.TRADE_ID,A.PLAN_ID,PL.NOTES,A.DESCRIPTION,A.HANGHOA_ID,HH.HH_CODE,HH.HH_NAME,A.CURRENCY,A.EXCHANGE_RATE,A.TAXES,
|
162
|
B.GD_CODE, B.GD_ID, B.GD_NAME, C.UNIT_CODE, C.UNIT_ID, A.UNIT_NAME,
|
163
|
|
164
|
ISNULL(PL.AMT_APP,0) AS AMT_APP,
|
165
|
ISNULL(PL.AMT_EXE,0) AS AMT_EXE,
|
166
|
ISNULL(PL.AMT_ETM,0) AS AMT_ETM,
|
167
|
ISNULL(PL.AMT_TF,0) AS AMT_TF,
|
168
|
ISNULL(PL.AMT_RECEIVE_TF,0) AS AMT_RECEIVE_TF,
|
169
|
ISNULL(PL.AMT_APP,0) + ISNULL(PL.AMT_RECEIVE_TF,0)-ISNULL(PL.AMT_TF,0) - ISNULL(PL.AMT_EXE,0) AS AMT_REMAIN,
|
170
|
ISNULL(PL.AMT_APP,0) + ISNULL(PL.AMT_RECEIVE_TF,0)-ISNULL(PL.AMT_TF,0)- ISNULL(PL.AMT_ETM,0) AS AMT_REMAIN_ETM,
|
171
|
ISNULL(PL.AMT_APP,0) + ISNULL(PL.AMT_RECEIVE_TF,0)-ISNULL(PL.AMT_TF,0)- ISNULL(PL.AMT_ETM,0)-ISNULL((SELECT SUM(Temp.TOTAL_AMT) AS TOTAL_AMT FROM dbo.PL_REQUEST_DOC_DT Temp WHERE Temp.REQ_ID=@P_REQ_ID AND Temp.TRADE_ID=A.TRADE_ID
|
172
|
AND EXISTS(SELECT REQ_ID FROM dbo.PL_REQUEST_DOC WHERE REQ_ID=@P_REQ_ID AND PROCESS_ID <>'APPROVE')
|
173
|
GROUP BY Temp.TRADE_ID),0)
|
174
|
AS AMT_REMAIN_REQ,
|
175
|
A.REQDT_TYPE,A.KHOI_ID,CK.DVDM_CODE AS KHOI_CODE,CK.DVDM_NAME AS KHOI_NAME,
|
176
|
A.DVDM_ID,DM.DVDM_CODE,DM.DVDM_NAME,A.TRADE_TYPE,A.SUP_ID,CS.SUP_NAME,CS.SUP_CODE,GT.GD_TYPE_NAME,GT.GD_TYPE_CODE,GT.GD_TYPE_ID,A.[NAME] AS REASON_CDT
|
177
|
FROM PL_REQUEST_DOC_DT A
|
178
|
LEFT JOIN @listTRADE PL ON A.TRADE_ID=PL.TRADE_ID
|
179
|
LEFT JOIN CM_GOODS B On A.GOODS_ID=B.GD_ID
|
180
|
LEFT JOIN dbo.CM_GOODSTYPE GT ON B.GD_CODE LIKE '%.' + GT.GD_TYPE_CODE +'.%'
|
181
|
LEFT JOIN CM_UNIT C On A.UNIT_ID=C.UNIT_ID
|
182
|
|
183
|
LEFT JOIN dbo.CM_DVDM DM ON DM.DVDM_ID=A.DVDM_ID
|
184
|
LEFT JOIN dbo.CM_DVDM CK ON CK.DVDM_ID=A.KHOI_ID
|
185
|
LEFT JOIN dbo.CM_HANGHOA HH ON HH.HH_ID=A.HANGHOA_ID
|
186
|
LEFT JOIN dbo.CM_SUPPLIER CS ON CS.SUP_ID=A.SUP_ID
|
187
|
WHERE A.REQ_ID=@P_REQ_ID
|
188
|
--AND (@ROLE='TGD' OR @IS_ALL=1 OR @ROLE='HDQT' OR @ROLE ='KSV' OR @ROLE ='GDV' OR EXISTS(SELECT * FROM @DVDM_ID WHERE [@DVDM_ID].DVDM_ID=A.DVDM_ID OR [@DVDM_ID].DVDM_ID=A.KHOI_ID )
|
189
|
--OR EXISTS
|
190
|
--(SELECT * FROM dbo.CM_GOOD_DVDM CGD WHERE CGD.GD_ID=A.GOODS_ID AND CGD.DVCM_ID IN (SELECT DVDM_ID FROM @DVDM_ID))
|
191
|
--OR EXISTS(SELECT * FROM dbo.PL_REQUEST_TRANSFER PT WHERE PT.TO_TRADE_ID=A.TRADE_ID AND PT.TO_GOOD_ID=A.GOODS_ID AND
|
192
|
--(PT.FR_BRN_ID=@BRANCH_ID AND ( PT.FR_DEP_ID=@DEP_ID OR PT.FR_DEP_ID IS NULL OR PT.FR_DEP_ID='') ))
|
193
|
--)
|
194
|
|
195
|
END
|
196
|
|
197
|
ELSE IF( @P_TYPE='PYC')
|
198
|
BEGIN
|
199
|
|
200
|
SELECT A.REQDT_ID,A.NAME,A.GOODS_ID,A.QUANTITY,A.TOTAL_AMT,A.PRICE,A.TRADE_ID,A.PLAN_ID,PL.NOTES,A.DESCRIPTION,A.HANGHOA_ID,HH.HH_CODE,HH.HH_NAME,A.CURRENCY,A.EXCHANGE_RATE,A.TAXES,
|
201
|
B.GD_CODE, B.GD_ID, B.GD_NAME, C.UNIT_CODE, C.UNIT_ID, A.UNIT_NAME,
|
202
|
ISNULL(PL.AMT_APP,0) AS AMT_APP,
|
203
|
ISNULL(PL.AMT_EXE,0) AS AMT_EXE,
|
204
|
ISNULL(PL.AMT_ETM,0) AS AMT_ETM,
|
205
|
ISNULL(PL.AMT_TF,0) AS AMT_TF,
|
206
|
ISNULL(PL.AMT_RECEIVE_TF,0) AS AMT_RECEIVE_TF,
|
207
|
ISNULL(PL.AMT_APP,0) + ISNULL(PL.AMT_RECEIVE_TF,0)-ISNULL(PL.AMT_TF,0) - ISNULL(PL.AMT_EXE,0) AS AMT_REMAIN,
|
208
|
ISNULL(PL.AMT_APP,0) + ISNULL(PL.AMT_RECEIVE_TF,0)-ISNULL(PL.AMT_TF,0)- ISNULL(PL.AMT_ETM,0) AS AMT_REMAIN_ETM,
|
209
|
ISNULL(PL.AMT_APP,0) + ISNULL(PL.AMT_RECEIVE_TF,0)-ISNULL(PL.AMT_TF,0)- ISNULL(PL.AMT_ETM,0)-ISNULL((SELECT SUM(Temp.TOTAL_AMT) AS TOTAL_AMT FROM dbo.PL_REQUEST_DOC_DT Temp WHERE Temp.REQ_ID=@P_REQ_ID AND Temp.TRADE_ID=A.TRADE_ID
|
210
|
AND EXISTS(SELECT REQ_ID FROM dbo.PL_REQUEST_DOC WHERE REQ_ID=@P_REQ_ID AND PROCESS_ID <>'APPROVE')
|
211
|
GROUP BY Temp.TRADE_ID),0)
|
212
|
AS AMT_REMAIN_REQ,
|
213
|
A.REQDT_TYPE,A.KHOI_ID,CK.DVDM_CODE AS KHOI_CODE,CK.DVDM_NAME AS KHOI_NAME,
|
214
|
A.DVDM_ID,DM.DVDM_CODE,DM.DVDM_NAME,A.TRADE_TYPE,A.SUP_ID,CS.SUP_NAME,CS.SUP_CODE,GT.GD_TYPE_NAME,GT.GD_TYPE_CODE,GT.GD_TYPE_ID,A.[NAME] AS REASON_CDT
|
215
|
FROM PL_REQUEST_DOC_DT A
|
216
|
LEFT JOIN @listTRADE PL ON A.TRADE_ID=PL.TRADE_ID
|
217
|
LEFT JOIN CM_GOODS B On A.GOODS_ID=B.GD_ID
|
218
|
LEFT JOIN dbo.CM_GOODSTYPE GT ON B.GD_CODE LIKE '%.' + GT.GD_TYPE_CODE +'.%'
|
219
|
LEFT JOIN CM_UNIT C On A.UNIT_ID=C.UNIT_ID
|
220
|
|
221
|
LEFT JOIN dbo.CM_DVDM DM ON DM.DVDM_ID=A.DVDM_ID
|
222
|
LEFT JOIN dbo.CM_DVDM CK ON CK.DVDM_ID=A.KHOI_ID
|
223
|
LEFT JOIN dbo.CM_HANGHOA HH ON HH.HH_ID=A.HANGHOA_ID
|
224
|
LEFT JOIN dbo.CM_SUPPLIER CS ON CS.SUP_ID=A.SUP_ID
|
225
|
WHERE A.REQ_ID=@P_REQ_ID
|
226
|
|
227
|
UNION ALL
|
228
|
|
229
|
SELECT A.REQDT_ID,A.NAME,A.GOODS_ID,A.QUANTITY,A.TOTAL_AMT,A.PRICE,A.TRADE_ID,A.PLAN_ID,PL.NOTES,A.DESCRIPTION,A.HANGHOA_ID,HH.HH_CODE,HH.HH_NAME,A.CURRENCY,A.EXCHANGE_RATE,A.TAXES,
|
230
|
B.GD_CODE, B.GD_ID, B.GD_NAME, C.UNIT_CODE, C.UNIT_ID, A.UNIT_NAME,
|
231
|
ISNULL(PL.AMT_APP,0) AS AMT_APP,
|
232
|
ISNULL(PL.AMT_EXE,0) AS AMT_EXE,
|
233
|
ISNULL(PL.AMT_ETM,0) AS AMT_ETM,
|
234
|
ISNULL(PL.AMT_TF,0) AS AMT_TF,
|
235
|
ISNULL(PL.AMT_RECEIVE_TF,0) AS AMT_RECEIVE_TF,
|
236
|
ISNULL(PL.AMT_APP,0) + ISNULL(PL.AMT_RECEIVE_TF,0)-ISNULL(PL.AMT_TF,0) - ISNULL(PL.AMT_EXE,0) AS AMT_REMAIN,
|
237
|
ISNULL(PL.AMT_APP,0) + ISNULL(PL.AMT_RECEIVE_TF,0)-ISNULL(PL.AMT_TF,0)- ISNULL(PL.AMT_ETM,0) AS AMT_REMAIN_ETM,
|
238
|
ISNULL(PL.AMT_APP,0) + ISNULL(PL.AMT_RECEIVE_TF,0)-ISNULL(PL.AMT_TF,0)- ISNULL(PL.AMT_ETM,0)-ISNULL((SELECT SUM(Temp.TOTAL_AMT) AS TOTAL_AMT FROM dbo.PL_REQUEST_DOC_DT Temp WHERE Temp.REQ_ID=@P_REQ_ID AND Temp.TRADE_ID=A.TRADE_ID
|
239
|
AND EXISTS(SELECT REQ_ID FROM dbo.PL_REQUEST_DOC WHERE REQ_ID=@P_REQ_ID AND PROCESS_ID <>'APPROVE')
|
240
|
GROUP BY Temp.TRADE_ID),0)
|
241
|
AS AMT_REMAIN_REQ,
|
242
|
A.REQDT_TYPE,A.KHOI_ID,CK.DVDM_CODE AS KHOI_CODE,CK.DVDM_NAME AS KHOI_NAME,
|
243
|
A.DVDM_ID,DM.DVDM_CODE,DM.DVDM_NAME,A.TRADE_TYPE,A.SUP_ID,CS.SUP_NAME,CS.SUP_CODE,GT.GD_TYPE_NAME,GT.GD_TYPE_CODE,GT.GD_TYPE_ID,A.[NAME] AS REASON_CDT
|
244
|
FROM PL_REQUEST_DOC_DT A
|
245
|
LEFT JOIN @listTRADE PL ON A.TRADE_ID=PL.TRADE_ID
|
246
|
LEFT JOIN CM_GOODS B On A.GOODS_ID=B.GD_ID
|
247
|
LEFT JOIN dbo.CM_GOODSTYPE GT ON B.GD_CODE LIKE '%.' + GT.GD_TYPE_CODE +'.%'
|
248
|
LEFT JOIN CM_UNIT C On A.UNIT_ID=C.UNIT_ID
|
249
|
|
250
|
LEFT JOIN dbo.CM_DVDM DM ON DM.DVDM_ID=A.DVDM_ID
|
251
|
LEFT JOIN dbo.CM_DVDM CK ON CK.DVDM_ID=A.KHOI_ID
|
252
|
LEFT JOIN dbo.CM_HANGHOA HH ON HH.HH_ID=A.HANGHOA_ID
|
253
|
LEFT JOIN dbo.CM_SUPPLIER CS ON CS.SUP_ID=A.SUP_ID
|
254
|
WHERE A.REQ_ID IN (SELECT REQ_ID FROM dbo.PL_REQUEST_DOC WHERE REQ_PARENT_ID =@P_REQ_ID)
|
255
|
END
|
256
|
|