22,210
社区成员
发帖
与我相关
我的任务
分享
(CASE WHEN exists(SELECT top 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND A.WO like @gd AND B.TAXUP > 0 )
THEN
(SELECT top 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 )
WHEN exists(
SELECT TOP 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 order by B.[DATETIME] desc )
THEN
(SELECT TOP 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 order by B.[DATETIME] DESC)
ELSE
(select TOP 1 TAXUP from VQUT WHERE VQUT.CODE=RESVT.CODE order by DATETIME DESC)
END)
CASE WHEN exists(SELECT top 1 B.TAXUP --如果此处存在则执行1,否则判断2,成立,执行3,不成立,执行4
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND A.WO like @gd AND B.TAXUP > 0 )
THEN --1
(SELECT top 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 )
ELSE
CASE WHEN --2
exists(
SELECT TOP 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 order by B.[DATETIME] desc )
THEN --3
(SELECT TOP 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 order by B.[DATETIME] DESC)
ELSE --4
(select TOP 1 TAXUP from VQUT WHERE VQUT.CODE=RESVT.CODE order by DATETIME DESC)
END
END
(CASE WHEN exists(SELECT top 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND A.WO like @gd AND B.TAXUP > 0 )
THEN
(SELECT top 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND A.WO like @gd AND B.TAXUP > 0 )
WHEN EXISTS (SELECT top 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 )
THEN
(SELECT top 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 )
WHEN exists(
SELECT TOP 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 order by B.[DATETIME] desc )
THEN
( SELECT TOP 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 order by B.[DATETIME] desc )
WHEN EXISTS (SELECT TOP 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 order by B.[DATETIME] DESC)
THEN
(SELECT TOP 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 order by B.[DATETIME] DESC)
ELSE
(select TOP 1 TAXUP from VQUT WHERE VQUT.CODE=RESVT.CODE order by DATETIME DESC)
END)DJ,
SELECT
(CASE WHEN a.MASTERJOB = '' THEN a.JOBNO ELSE a.MASTERJOB END) AS WO,
JOBNO,
a.CHILDJOB,
a.CODE,
a.BDESC,
a.P_CODE,
b.CBDESC,
a.QTY,
a.UNIT,
a.LOC,
ISNULL(c.TAXUP,d.TAXUP) AS DJ,
(CASE WHEN CHILDJOB='' THEN JOBNO ELSE CHILDJOB END)AS W,
e.QTY AS T,
e.QTY2 AS BL,
h.TL,
i.VEN,
j.qty_nee AS QTY_NEE,
j.SH
FROM RESVT AS a
OUTER APPLY
(SELECT TOP 1 BDESC FROM PRO WHERE CODE=a.P_CODE)AS b
OUTER APPLY
(SELECT top 1 TAXUP
FROM ANT x LEFT JOIN ANTUDF y ON (x.PANNO=y.PANNO and x.ITEMNO=y.ITEMNO)
WHERE x.CODE=a.CODE AND y.TAXUP > 0 ORDER BY CASE WHEN x.WO=@gd THEN 1 ELSE 2 END,order by B.[DATETIME] desc)AS c --like 改為 =
OUTER APPLY
(select TOP 1 TAXUP from VQUT WHERE CODE=a.CODE order by [DATETIME] DESC) AS d
OUTER APPLY
(SELECT TOP 1 SUM(QTY) AS QTY,SUM(CASE WHEN MRNO LIKE '%HCBL%' THEN QTY ELSE 0 end) AS QTY2 FROM MRT WHERE JOBNO=a.JOBNO AND CODE=a.CODE AND P_CODE=a.P_CODE) AS e
OUTER APPLY
(select TOP 1 SUM(BADQTY+PBADQTY+RETUQTY) AS TL from PRT
Left JOIN PRTUDF ON PRT.PRNO=PRTUDF.PRNO AND PRT.ITEMNO=PRTUDF.ITEMNO WHERE JOBNO=a.JOBNO AND CODE=a.CODE AND P_CODE=a.P_CODE) AS h
OUTER APPLY
(SELECT TOP 1 VEN FROM ANT x1 LEFT JOIN ANTUDF y1 ON (x1.PANNO=y1.PANNO and x1.ITEMNO=y1.ITEMNO)WHERE x1.CODE=a.CODE AND y1.WO = @gd ) AS i
OUTER APPLY
(SELECT TOP 1 qty_nee,sh from #tree where #tree.code=a.CODE AND #tree.p_code=a.P_CODE) AS j
WHERE a.MASTERJOB = '' AND a.JOBNO=@gd OR MASTERJOB=@gd
這樣測測
SELECT
(CASE WHEN a.MASTERJOB = '' THEN a.JOBNO ELSE a.MASTERJOB END) AS WO,
JOBNO,
a.CHILDJOB,
a.CODE,
a.BDESC,
a.P_CODE,
b.CBDESC,
a.QTY,
a.UNIT,
a.LOC,
ISNULL(c.TAXUP,d.TAXUP) AS DJ,
(CASE WHEN CHILDJOB='' THEN JOBNO ELSE CHILDJOB END)AS W,
e.QTY AS T,
f.QTY AS BL,
h.TL,
i.VEN,
j.qty_nee AS QTY_NEE,
j.SH
FROM RESVT AS a
OUTER APPLY
(SELECT TOP 1 BDESC FROM PRO WHERE CODE=a.P_CODE)AS b
OUTER APPLY
(SELECT top 1 TAXUP
FROM ANT x LEFT JOIN ANTUDF y ON (x.PANNO=y.PANNO and x.ITEMNO=y.ITEMNO)
WHERE x.CODE=a.CODE AND y.TAXUP > 0 ORDER BY CASE WHEN x.WO=@gd THEN 1 ELSE 2 END,order by B.[DATETIME] desc)AS c --like 改為 =
OUTER APPLY
(select TOP 1 TAXUP from VQUT WHERE CODE=a.CODE order by [DATETIME] DESC) AS d
OUTER APPLY
(SELECT TOP 1 SUM(QTY) AS QTY FROM MRT WHERE JOBNO=a.JOBNO AND CODE=a.CODE AND P_CODE=a.P_CODE) AS e
OUTER APPLY
(SELECT TOP 1 SUM(QTY) AS QTY FROM MRT WHERE JOBNO=a.JOBNO AND CODE=a.CODE AND P_CODE=a.P_CODE AND MRNO LIKE '%HCBL%' ) AS f
OUTER APPLY
(select TOP 1 SUM(BADQTY+PBADQTY+RETUQTY) AS TL from PRT
Left JOIN PRTUDF ON PRT.PRNO=PRTUDF.PRNO AND PRT.ITEMNO=PRTUDF.ITEMNO WHERE JOBNO=a.JOBNO AND CODE=a.CODE AND P_CODE=a.P_CODE) AS h
OUTER APPLY
(SELECT TOP 1 VEN FROM ANT x1 LEFT JOIN ANTUDF y1 ON (x1.PANNO=y1.PANNO and x1.ITEMNO=y1.ITEMNO)WHERE x1.CODE=a.CODE AND y1.WO = @gd ) AS i
OUTER APPLY
(SELECT TOP 1 qty_nee,sh from #tree where #tree.code=a.CODE AND #tree.p_code=a.P_CODE) AS j
WHERE a.MASTERJOB = '' AND a.JOBNO=@gd OR MASTERJOB=@gd
(CASE WHEN exists(SELECT top 1 TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND A.WO like @gd AND B.TAXUP > 0 )
THEN ----1
(SELECT top 1 TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 ) --AND charindex(@gd,WO)>0
WHEN ------2
exists(
SELECT top 1 TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND A.WO like @gd AND B.TAXUP > 0
踢出去执行他是有结果的。结果是0.010SELECT (CASE WHEN MASTERJOB = '' THEN JOBNO ELSE MASTERJOB END)WO,JOBNO,CHILDJOB,CODE,BDESC,P_CODE,
(SELECT TOP 1 BDESC FROM PRO WHERE CODE=RESVT.P_CODE)CBDESC,QTY,UNIT,LOC,
(CASE WHEN exists(SELECT top 1 TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND A.WO like @gd AND B.TAXUP > 0 )
THEN
(SELECT top 1 TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 ) --AND charindex(@gd,WO)>0
WHEN exists(
SELECT TOP 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 order by B.[DATETIME] desc )
THEN
(SELECT TOP 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 order by B.[DATETIME] DESC)
ELSE
(select TOP 1 TAXUP from VQUT WHERE VQUT.CODE=RESVT.CODE order by [DATETIME] DESC)
END)DJ,
(CASE WHEN CHILDJOB='' THEN JOBNO ELSE CHILDJOB END)W,
(SELECT TOP 1 SUM(QTY) FROM MRT WHERE JOBNO=RESVT.JOBNO AND CODE=RESVT.CODE AND P_CODE=RESVT.P_CODE)T,
(SELECT TOP 1 SUM(QTY) FROM MRT WHERE JOBNO=RESVT.JOBNO AND CODE=RESVT.CODE AND P_CODE=RESVT.P_CODE AND MRNO LIKE '%HCBL%' )BL,
(select TOP 1 SUM(BADQTY+PBADQTY+RETUQTY) from PRT Left JOIN PRTUDF ON PRT.PRNO=PRTUDF.PRNO AND PRT.ITEMNO=PRTUDF.ITEMNO WHERE JOBNO=RESVT.JOBNO AND CODE=RESVT.CODE AND P_CODE=RESVT.P_CODE)TL,
(SELECT TOP 1 VEN FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)WHERE B.CODE=RESVT.CODE AND A.WO like @gd )VEN,
(SELECT TOP 1 qty_nee from #tree where #tree.code=RESVT.CODE AND #tree.p_code=RESVT.P_CODE)QTY_NEE,
(SELECT TOP 1 sh from #tree where #tree.code=RESVT.CODE AND #tree.p_code=RESVT.P_CODE)SH
FROM RESVT WHERE 1=1 and (CASE WHEN MASTERJOB = '' THEN JOBNO ELSE MASTERJOB END)=@gd
(CASE WHEN exists(SELECT top 1 B.TAXUP --如果此处存在则执行1
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND A.WO like @gd AND B.TAXUP > 0 )
THEN --1
(SELECT top 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 )
WHEN exists( --如果此处存在则执行2
SELECT TOP 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 order by B.[DATETIME] desc )
THEN --2
(SELECT TOP 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=RESVT.CODE AND B.TAXUP > 0 order by B.[DATETIME] DESC)
ELSE --如果上述两个都不存在,则执行此处
(select TOP 1 TAXUP from VQUT WHERE VQUT.CODE=RESVT.CODE order by DATETIME DESC)
END)
set ANSI_NULLS ON
set QUOTED_IDENTIFIER ON
go
ALTER PROCEDURE [dbo].[P_DJ]
(
@deeplevel int,
@firstcode nvarchar(100),
@firstcodes nvarchar(100),
@gd nvarchar(100),
@isLeafnode int
)
AS
SET NOCOUNT ON
SET XACT_ABORT ON
BEGIN
create table #tree
(
bomno nvarchar(100),
code nvarchar(100),
p_code nvarchar(100),
deeplevel int,
cbdesc nvarchar(100),
qty_nee numeric(19,8),
loc varchar(32),
wastage numeric(6,2),
sh numeric(19,8),
isLeafnode int,
tree nvarchar(max) default ''
)
declare
@cbdesc varchar(32),
@QTY_NEED numeric(19,8),
@loc varchar(32),
@wastage numeric(6,2)
insert #tree
select BOMT.BOMNO,BOMT.CODE,BOMT.P_CODE,@deeplevel,BOMT.CBDESC,BOMT.QTY_NEED,MAINBOM.LOC,BOMT.WASTAGE,(WASTAGE/100),1,
BOMT.CODE + left('00000000000000000000',20-len(BOMT.CODE)) from BOMT left JOIN MAINBOM on BOMT.CODE=MAINBOM.BOMNO where BOMT.BOMNO IN(@firstcode,@firstcodes)
WHILE @@rowcount > 0
BEGIN
SET @deeplevel = @deeplevel + 1
update #tree set isLeafnode= 0 from #tree
join BOMT
on #tree.deeplevel=@deeplevel-1
and BOMT.BOMNO collate database_default =#tree.code
insert #tree
select @firstcode,BOMT.CODE,BOMT.P_CODE,@deeplevel,BOMT.CBDESC,BOMT.QTY_NEED,MAINBOM.LOC,BOMT.WASTAGE,sh+(WASTAGE/100),1,#tree.tree+'_'+BOMT.CODE+left('00000000000000000000',20-len(BOMT.CODE))
from BOMT
join #tree
on #tree.deeplevel=@deeplevel-1
and BOMT.BOMNO collate database_default =#tree.code
left join MAINBOM
on BOMT.CODE=MAINBOM.BOMNO
END
SELECT
(CASE WHEN a.MASTERJOB = '' THEN a.JOBNO ELSE a.MASTERJOB END) AS WO,
JOBNO,
a.CHILDJOB,
a.CODE,
a.BDESC,
a.P_CODE,
b.CBDESC,
a.QTY,
a.UNIT,
a.LOC,
(CASE WHEN exists(SELECT top 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=a.CODE AND A.WO like @gd AND B.TAXUP > 0 )
THEN
(SELECT top 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=a.CODE AND A.WO like @gd AND B.TAXUP > 0 )
WHEN EXISTS (SELECT top 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=a.CODE AND B.TAXUP > 0 )
THEN
(SELECT top 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=a.CODE AND B.TAXUP > 0 )
WHEN exists(SELECT TOP 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=a.CODE AND B.TAXUP > 0 order by B.[DATETIME] desc )
THEN
(SELECT TOP 1 B.TAXUP
FROM ANT B LEFT JOIN ANTUDF A ON (B.PANNO=A.PANNO and B.ITEMNO=A.ITEMNO)
WHERE B.CODE=a.CODE AND B.TAXUP > 0 order by B.[DATETIME] desc )
ELSE
(select TOP 1 TAXUP from VQUT WHERE VQUT.CODE=a.CODE order by DATETIME DESC)
END)DJ,
e.QTY AS T,
f.QTY AS BL,
h.TL,
i.VEN,
j.qty_nee AS QTY_NEE,
j.sh
FROM RESVT AS a
OUTER APPLY
(SELECT TOP 1 CBDESC FROM PRO WHERE CODE=a.P_CODE)AS b
OUTER APPLY
(SELECT TOP 1 SUM(QTY) AS QTY FROM MRT WHERE JOBNO=a.JOBNO AND CODE=a.CODE AND P_CODE=a.P_CODE) AS e
OUTER APPLY
(SELECT TOP 1 SUM(QTY) AS QTY FROM MRT WHERE JOBNO=a.JOBNO AND CODE=a.CODE AND P_CODE=a.P_CODE AND MRNO LIKE '%HCBL%' ) AS f
OUTER APPLY
(select TOP 1 SUM(BADQTY+PBADQTY+RETUQTY) AS TL from PRT
Left JOIN PRTUDF ON PRT.PRNO=PRTUDF.PRNO AND PRT.ITEMNO=PRTUDF.ITEMNO WHERE JOBNO=a.JOBNO AND CODE=a.CODE AND P_CODE=a.P_CODE) AS h
OUTER APPLY
(SELECT TOP 1 VEN FROM ANT x1 LEFT JOIN ANTUDF y1 ON (x1.PANNO=y1.PANNO and x1.ITEMNO=y1.ITEMNO)WHERE x1.CODE=a.CODE AND y1.WO = @gd ) AS i
OUTER APPLY
(SELECT TOP 1 qty_nee,sh from #tree where #tree.code=a.CODE AND #tree.p_code=a.P_CODE) AS j
WHERE 1=1 and (CASE WHEN a.MASTERJOB = '' THEN a.JOBNO ELSE a.MASTERJOB END)=@gd and a.CHILDJOB=''
RETURN @@ERROR END
SET NOCOUNT OFF
SET XACT_ABORT OFF
EXEC P_DJ 1,'WI-EGD-3862','WI-EGD-B0867',1107014,1
在数据库里面能正常执行。
SELECT
(CASE WHEN a.MASTERJOB = '' THEN a.JOBNO ELSE a.MASTERJOB END) AS WO,
a.JOBNO,
a.CHILDJOB,
a.CODE,
a.BDESC,
a.P_CODE,
b.CBDESC,
a.QTY,
a.UNIT,
a.LOC,
ISNULL(c.TAXUP,d.TAXUP) AS DJ,
(CASE WHEN a.CHILDJOB='' THEN a.JOBNO ELSE a.CHILDJOB END)AS W,
e.QTY AS T,
e.QTY2 AS BL,
h.TL,
i.VEN,
j.qty_nee AS QTY_NEE,
j.SH
FROM RESVT AS a
OUTER APPLY
(SELECT TOP 1 BDESC FROM PRO WHERE CODE=a.P_CODE)AS b
OUTER APPLY
(SELECT top 1 TAXUP
FROM ANT x LEFT JOIN ANTUDF y ON (x.PANNO=y.PANNO and x.ITEMNO=y.ITEMNO)
WHERE x.CODE=a.CODE AND y.TAXUP > 0 ORDER BY CASE WHEN x.WO=@gd THEN 1 ELSE 2 END,order by B.[DATETIME] desc)AS c --like 改為 =
OUTER APPLY
(select TOP 1 TAXUP from VQUT WHERE CODE=a.CODE order by [DATETIME] DESC) AS d
OUTER APPLY
(SELECT TOP 1 SUM(QTY) AS QTY,SUM(CASE WHEN MRNO LIKE '%HCBL%' THEN QTY ELSE 0 end) AS QTY2 FROM MRT WHERE JOBNO=a.JOBNO AND CODE=a.CODE AND P_CODE=a.P_CODE) AS e
OUTER APPLY
(select TOP 1 SUM(BADQTY+PBADQTY+RETUQTY) AS TL from PRT
Left JOIN PRTUDF ON PRT.PRNO=PRTUDF.PRNO AND PRT.ITEMNO=PRTUDF.ITEMNO WHERE JOBNO=a.JOBNO AND CODE=a.CODE AND P_CODE=a.P_CODE) AS h
OUTER APPLY
(SELECT TOP 1 VEN FROM ANT x1 LEFT JOIN ANTUDF y1 ON (x1.PANNO=y1.PANNO and x1.ITEMNO=y1.ITEMNO)WHERE x1.CODE=a.CODE AND y1.WO = @gd ) AS i
OUTER APPLY
(SELECT TOP 1 qty_nee,sh from #tree where #tree.code=a.CODE AND #tree.p_code=a.P_CODE) AS j
WHERE a.MASTERJOB = '' AND a.JOBNO=@gd OR MASTERJOB=@gd