在加入语句Oracle中使用案例

时间:2014-06-10 02:28:35

标签: sql oracle11g

如果可以有条件地连接两个表,我一直在尝试。下面是我所做的一个示例,但它返回错误ORA-00905:Missing Keyword。

WITH rejects AS
(
  SELECT
    c.containername
    , c.containerid
    , rlhd.waferscribenumber
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_BLISTER', rlhd.totalqty)), 0) WLP_BLISTER
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_CAMTEKREJECTS', rlhd.totalqty)), 0) WLP_CAMTEKREJECTS
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_CHIP-OUT', rlhd.totalqty)), 0) WLP_CHIPOUT
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_LIQUID_CONTAM', rlhd.totalqty)), 0) WLP_LIQUID_CONTAM
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_OPAQUE_CONTAM', rlhd.totalqty)), 0) WLP_OPAQUE_CONTAM
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_CORROSION', rlhd.totalqty)), 0) WLP_CORROSION
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_CRACKED_OR_BROKEN_WAFER', rlhd.totalqty)), 0) WLP_CRACKED_OR_BROKEN_WAFER
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_DIFFUSION_FAULT', rlhd.totalqty)), 0) WLP_DIFFUSION_FAULT
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_EDGE_DIE', rlhd.totalqty)), 0) WLP_EDGE_DIE
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_EXCESSMETAL', rlhd.totalqty)), 0) WLP_EXCESSMETAL
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_EXCESS_PROBE_MARK', rlhd.totalqty)), 0) WLP_EXCESS_PROBE_MARK
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_FADED_INK', rlhd.totalqty)), 0) WLP_FADED_INK
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_FLY-OFF_DIE', rlhd.totalqty)), 0) WLP_FLYOFF_DIE
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_FOREIGN_MATERIALS', rlhd.totalqty)), 0) WLP_FOREIGN_MATERIALS
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_GLASSIVATION', rlhd.totalqty)), 0) WLP_GLASSIVATION
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_INCOMPLETETRIM', rlhd.totalqty)), 0) WLP_INCOMPLETETRIM
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_INK_SPLATTER', rlhd.totalqty)), 0) WLP_INK_SPLATTER
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_LASERPINHOLE', rlhd.totalqty)), 0) WLP_LASERPINHOLE
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_LASERTRIM', rlhd.totalqty)), 0) WLP_LASERTRIM
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_LIGHT_HAZES', rlhd.totalqty)), 0) WLP_LIGHT_HAZES
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_METAL_BRIDGE', rlhd.totalqty)), 0) WLP_METAL_BRIDGE
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_METAL_VOID', rlhd.totalqty)), 0) WLP_METAL_VOID
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_MISALIGN_SCRIBE', rlhd.totalqty)), 0) WLP_MISALIGN_SCRIBE
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_OTHERS', rlhd.totalqty)), 0) WLP_OTHERS
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_PASSIVATION_FAULT', rlhd.totalqty)), 0) WLP_PASSIVATION_FAULT
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_PROBE_DAMAGE', rlhd.totalqty)), 0) WLP_PROBE_DAMAGE
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_METAL_SCRATCH_OVER', rlhd.totalqty)), 0) WLP_METAL_SCRATCH_OVER
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_METAL_SCRATCH_UNDER', rlhd.totalqty)), 0) WLP_METAL_SCRATCH_UNDER
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_THROWAWAY_DIES', rlhd.totalqty)), 0) WLP_THROWAWAYDIES
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_UNPROBE_DIE', rlhd.totalqty)), 0) WLP_UNPROBE_DIE
    , NVL(MAX(DECODE(rlhd.LossReasonName, 'WLP_WO_LETTER_EFG', rlhd.totalqty)), 0) WLP_WO_LETTER_EFG
  FROM CONTAINER c
  JOIN a_rejectlothistory rlh ON c.containerid = rlh.historyid
  JOIN a_rejectlothistorydetails rlhd ON rlh.rejectlothistoryid = rlhd.rejectlothistoryid
  WHERE rlhd.specname IN ('8810_DS_VISUAL_INS_WS', '8810_WS_VISUAL_INS_WS', '7202_POST_WAFFLE_PACK_INSPECTION_WS')
  GROUP BY c.containername
           , c.containerid
           , rlhd.waferscribenumber
  ORDER BY c.containername
)

SELECT DISTINCT
  SUBSTR((SELECT(otherdb.pkg_calendar.fncalendar(wl.moveouttimestamp, 'YYYYWW')) AS wwkdate FROM dual), 0, LENGTH((SELECT(otherdb.pkg_calendar.fncalendar(wl.moveintimestamp, 'YYYYWW')) AS wwkdate FROM dual))-2) YEAR
  , SUBSTR((SELECT(otherdb.pkg_calendar.fncalendar(wl.moveouttimestamp, 'YYYYQ')) AS wwkdate FROM dual), -1) quarter
  , SUBSTR((SELECT(otherdb.pkg_calendar.fncalendar(wl.moveouttimestamp, 'YYYYWW')) AS wwkdate FROM dual), -2) WW
  , to_char(wl.moveouttimestamp, 'MM/DD/YYYY HH:MI:SS PM') ddate
  , CASE WHEN to_char(wl.moveouttimestamp, 'HH24') > 18 THEN 'C3' ELSE 'A2' END shift
  , c.containername Lotnum
  , wl.productname device
  , lw.wafernumber
  , p.description CATEGORY
  , wl.moveinqty qty_in
  , wl.moveoutqty qty_out
  , DECODE(wl.moveinqty, 0, 'N/A', ROUND((wl.moveoutqty / wl.moveinqty) * 100, 4)) yield
  , NVL(r.WLP_BLISTER, 0) WLP_BLISTER
  , NVL(r.WLP_CAMTEKREJECTS, 0) WLP_CAMTEKREJECTS
  , NVL(r.WLP_CHIPOUT, 0) WLP_CHIPOUT
  , NVL(r.WLP_LIQUID_CONTAM, 0) WLP_LIQUID_CONTAM
  , NVL(r.WLP_OPAQUE_CONTAM, 0) WLP_OPAQUE_CONTAM
  , NVL(r.WLP_CORROSION, 0) WLP_CORROSION
  , NVL(r.WLP_CRACKED_OR_BROKEN_WAFER, 0) WLP_CRACKED_OR_BROKEN_WAFER
  , NVL(r.WLP_DIFFUSION_FAULT, 0) WLP_DIFFUSION_FAULT
  , NVL(r.WLP_EDGE_DIE, 0) WLP_EDGE_DIE
  , NVL(r.WLP_EXCESSMETAL, 0) WLP_EXCESSMETAL
  , NVL(r.WLP_EXCESS_PROBE_MARK, 0) WLP_EXCESS_PROBE_MARK
  , NVL(r.WLP_FADED_INK, 0) WLP_FADED_INK
  , NVL(r.WLP_FLYOFF_DIE, 0) WLP_FLYOFF_DIE
  , NVL(r.WLP_FOREIGN_MATERIALS, 0) WLP_FOREIGN_MATERIALS
  , NVL(r.WLP_GLASSIVATION, 0) WLP_GLASSIVATION
  , NVL(r.WLP_INCOMPLETETRIM, 0) WLP_INCOMPLETETRIM
  , NVL(r.WLP_INK_SPLATTER, 0) WLP_INK_SPLATTER
  , NVL(r.WLP_LASERPINHOLE, 0) WLP_LASERPINHOLE
  , NVL(r.WLP_LASERTRIM, 0) WLP_LASERTRIM
  , NVL(r.WLP_LIGHT_HAZES, 0) WLP_LIGHT_HAZES
  , NVL(r.WLP_METAL_BRIDGE, 0) WLP_METAL_BRIDGE
  , NVL(r.WLP_METAL_VOID, 0) WLP_METAL_VOID
  , NVL(r.WLP_MISALIGN_SCRIBE, 0) WLP_MISALIGN_SCRIBE
  , NVL(r.WLP_OTHERS, 0) WLP_OTHERS
  , NVL(r.WLP_PASSIVATION_FAULT, 0) WLP_PASSIVATION_FAULT
  , NVL(r.WLP_PROBE_DAMAGE, 0) WLP_PROBE_DAMAGE
  , NVL(r.WLP_METAL_SCRATCH_OVER, 0) WLP_METAL_SCRATCH_OVER
  , NVL(r.WLP_METAL_SCRATCH_UNDER, 0) WLP_METAL_SCRATCH_UNDER
  , NVL(r.WLP_THROWAWAYDIES, 0) WLP_THROWAWAYDIES
  , NVL(r.WLP_UNPROBE_DIE, 0) WLP_UNPROBE_DIE
  , NVL(r.WLP_WO_LETTER_EFG, 0) WLP_WO_LETTER_EFG
  , wl.specname
FROM CONTAINER c
JOIN product p ON c.productid = p.productid
JOIN a_wiplothistory wl ON c.containerid = wl.containerid
JOIN a_lotwafers lw ON c.containerid = lw.containerid
LEFT JOIN rejects r ON CASE WHEN wl.specname =  '8810_WS_VISUAL_INS_WS' THEN c.containerid = r.containerid AND lw.waferscribenumber = r.waferscribenumber
                       ELSE c.containerid = r.containerid
                       END
WHERE c.containername NOT LIKE '%TEST%' AND c.containername NOT LIKE '%TST%' AND wl.specname IN ('8810_DS_VISUAL_INS_WS', '7202_POST_WAFFLE_PACK_INSPECTION_WS', '8810_WS_VISUAL_INS_WS')
;

有关如何实现这一点的任何想法?谢谢。

1 个答案:

答案 0 :(得分:0)

您缺少的关键字就是这一行:

LEFT JOIN rejects r ON CASE WHEN wl.specname =  '8810_WS_VISUAL_INS_WS' THEN c.containerid = r.containerid AND lw.waferscribenumber = r.waferscribenumber
                       ELSE c.containerid = r.containerid
                       END

我建议您在没有case的情况下写这个:

LEFT JOIN rejects r
ON c.containerid = r.containerid AND
   ((wl.specname = '8810_WS_VISUAL_INS_WS' AND lw.waferscribenumber = r.waferscribenumber) OR
    ((wl.specname <> '8810_WS_VISUAL_INS_WS' OR wl.specname IS NULL)
   )

在Oracle中,case语句不能返回布尔表达式。您可以将条件写为:

LEFT JOIN rejects r
ON c.containerid = r.containerid AND
   (case when (wl.specname = '8810_WS_VISUAL_INS_WS' then lw.waferscribenumber
         else r.waferscribenumber
    end) = r.waferscribenumber

但我认为第一种方法更清晰。