实现脚本:

DROP VIEW "IPS_CC_InvtryTransFlow";

CREATE VIEW "IPS_CC_InvtryTransFlow"

AS

SELECT

T0."LogEntry",

T0."ItemCode",

T0."ItemName",

T0."DocNum",

T0."DocEntry",

T0."DocLine",

T0."DocType",

ABS(T1."Quantity") AS "IOQuantity",

CASE WHEN T1."Quantity">0 THEN 'I' ELSE 'O' END AS "IOType",

CASE WHEN T1."Quantity">0 THEN '入' ELSE '出' END AS "IODirt",

CASE WHEN T1."Quantity">0

   THEN IO."LocCode" 

   ELSE NULL

   END AS "FromWhsCode", 

CASE WHEN T1."Quantity">0

   THEN IOW."WhsName" 

   ELSE NULL

   END AS "FromWhsName", 

T0."LocCode" AS "WhsCode",

T2."WhsName",

CASE WHEN T1."Quantity">0

   THEN NULL

   ELSE IO."LocCode" 

   END AS "ToWhsCode", 

CASE WHEN T1."Quantity">0

   THEN NULL

   ELSE IOW."WhsName" 

   END AS "ToWhsName",  

CASE WHEN IT."ManSerNum"='Y'

   THEN SR."MnfSerial"

   ELSE NULL END AS "MnfSerial", 

CASE WHEN IT."ManSerNum"='Y' THEN SR."DistNumber"

   WHEN IT."ManBtchNum"='Y' THEN BT."DistNumber"

   ELSE NULL END AS "DistNumber",

CASE WHEN IT."ManSerNum"='Y'

   THEN SR."LotNumber"

   ELSE NULL END "LotNumber",

T1."Quantity",

IT."ManSerNum",

IT."ManBtchNum",

CAST(T0."CreateDate" AS NVARCHAR(10))||' '||TO_TIME(LPAD(T0."CreateTime",6,'0'),'HHMISS') AS "CreateTime"

FROM "OITL" T0

INNER JOIN "OITM" IT ON IT."ItemCode"=T0."ItemCode"

INNER JOIN "ITL1" T1 ON T1."LogEntry"=T0."LogEntry"

INNER JOIN "OWHS" T2 ON T2."WhsCode"=T0."LocCode"

LEFT JOIN "OSRN" SR ON SR."ItemCode"=T0."ItemCode" AND SR."SysNumber"=T1."SysNumber"

LEFT JOIN "OBTN" BT ON BT."ItemCode"=T0."ItemCode" AND BT."SysNumber"=T1."SysNumber"

LEFT JOIN "OITL" IO ON IO."ItemCode"=T0."ItemCode" AND IO."DocEntry"=T0."DocEntry"

               AND IO."DocLine"=T0."DocLine" AND IO."DocType"=T0."DocType" 

               AND IO."LogEntry"<>T0."LogEntry"

LEFT JOIN "OWHS" IOW ON IOW."WhsCode"=IO."LocCode"

ORDER BY T0."LogEntry";

发表评论