2016-04-28 27 views
0

我在oracle中執行此查詢,它在第33行給我一個錯誤的右括號錯誤。是否有任何人可以幫助我解決此問題。謝謝 這裏是我的查詢在oracle中執行此查詢時丟失右方括號錯誤

WITH t AS (
    SELECT RM_LIVE.EMPLOYEE.EMPNO, 
     RM_LIVE.EMPNAME.FIRSTNAME, 
     RM_LIVE.EMPNAME.LASTNAME, 
     RM_LIVE.CRWBASE.BASE, 
     RM_LIVE.CRWCAT.crwcat, 
     RM_LIVE.CRWSPECFUNC.IDCRWSPECFUNC 
    FROM RM_LIVE.EMPBASE, 
     RM_LIVE.EMPLOYEE, 
     RM_LIVE.CRWBASE, 
     RM_LIVE.EMPNAME, 
     RM_LIVE.CRWSPECFUNC, 
     RM_LIVE.EMPSPECFUNC, 
     RM_LIVE.EMPQUALCAT, 
     RM_LIVE.CRWCAT 
    where RM_LIVE.EMPBASE.IDEMPNO = RM_LIVE.EMPLOYEE.IDEMPNO 
    AND RM_LIVE.EMPBASE.IDCRWBASE = RM_LIVE.CRWBASE.IDCRWBASE 
    AND RM_LIVE.EMPLOYEE.IDEMPNO = RM_LIVE.EMPNAME.IDEMPNO 
    AND RM_LIVE.EMPSPECFUNC.IDCRWSPECFUNC =RM_LIVE.CRWSPECFUNC.IDCRWSPECFUNC 
    AND RM_LIVE.EMPSPECFUNC.IDEMPNO =RM_LIVE.EMPLOYEE.IDEMPNO 
    AND RM_LIVE.EMPQUALCAT.IDEMPNO=RM_LIVE.EMPLOYEE.IDEMPNO 
    AND RM_LIVE.CRWCAT.IDCRWCAT = RM_LIVE.EMPQUALCAT.IDCRWCAT 
    AND RM_LIVE.CRWCAT.crwcat IN ('CP','FO','CM','MC') 
    AND RM_LIVE.CRWBASE.BASE <> 'XYZ' 
    AND RM_LIVE.CRWSPECFUNC.IDCRWSPECFUNC IN 
       ('921','2' ,'1','301','17','4','3','7','302' ,'861','31', 
       '723','30','722 ','29 ','721','16','601','581') 
    AND RM_LIVE.EMPBASE.STARTDATE <= SYSDATE 
    AND RM_LIVE.EMPBASE.ENDDATE >= SYSDATE 
    AND RM_LIVE.EMPSPECFUNC.STARTDATE <= SYSDATE 
    AND RM_LIVE.EMPSPECFUNC.ENDDATE >= SYSDATE 
    AND RM_LIVE.EMPNAME.FROMDATE <=SYSDATE 
    AND RM_LIVE.EMPQUALCAT.STARTDATE <= SYSDATE 
    AND RM_LIVE.EMPQUALCAT.ENDDATE >= SYSDATE AS ta (EMPNO,EMPFIRSTNAME,EMPLASTNAME, Base, CAT, code) 
) 
SELECT DISTINCT 
     t.EMPNO, 
     t.EMPFIRSTNAME, 
     t.EMPLASTNAME, 
     t.Base, 
     t.CAT, 
     (ABS(oa.val1) * NVL(NULLIF((ABS(oa.val2) * ABS(oa.val3)),0),1) * ABS(oa.val4) * ABS(oa.val5) * ABS(oa.val6) * ABS(oa.val7) * ABS(oa.val8) * ABS(oa.val9)) AS "FTE VALUE" 
FROM t 
    OUTER APPLY (SELECT MAX(CASE WHEN t2.code IN (1,2,4) THEN 0.70 ELSE -1 END) AS val1, 
         MAX(CASE WHEN t2.code IN (1,2) THEN 0 ELSE -1 END) AS val2, 
         MAX(CASE WHEN t2.code IN (4) THEN 1.29 ELSE -1 END) AS val3, 
         MAX(CASE WHEN t2.code IN (861) THEN 0.80 ELSE -1 END) AS val4 
         MAX(CASE WHEN t2.code IN (921,301,30,722,601,581) THEN 0.50 ELSE -1 END) AS val5 
         MAX(CASE WHEN t2.code IN (17,302,16) THEN 0.85 ELSE -1 END) AS val6 
         MAX(CASE WHEN t2.code IN (29,721) THEN 0.25 ELSE -1 END) AS val7 
         MAX(CASE WHEN t2.code IN (31,723) THEN 0.75 ELSE -1 END) AS val8 
         MAX(CASE WHEN t2.code IN (3,7) THEN 0.90 ELSE -1 END) AS val9 
        FROM t AS t2 WHERE t2.EMPNO = t.EMPNO) oa 
+1

請不要混合遺留(逗號)連接和ANSI/ISO連接 - 只是將所有內容都轉換爲ANSI連接(查看錶格的相關性如此容易)。 – MT0

+0

'OUTER APPLY'做什麼?這是來自另一個DBMS的語法嗎? 'AS ta(EMPNO,EMPFIRSTNAME,EMPLASTNAME,Base,CAT,code)'應該是做什麼的? –

+1

@AlexPoole'OUTER APPLY'似乎是[12c功能](https://docs.oracle.com/database/121/SQLRF/statements_10002.htm#BABJHDDA) - 但是,OP僅標記了早期版本的Oracle 。 – MT0

回答

1

你的子查詢保的最後一行(WITH ... AS (...))子句是:

AND RM_LIVE.EMPQUALCAT.ENDDATE >= SYSDATE AS ta (EMPNO,EMPFIRSTNAME,EMPLASTNAME, Base, CAT, code) 

AS ta (...)是無效的語法。

如果你想命名列,那麼你需要刪除部分,第一行更改爲:

WITH t (EMPNO,EMPFIRSTNAME,EMPLASTNAME, Base, CAT, code) AS (

然而,這是Oracle 11g中引入的語法,不會在Oracle 10g的工作 - 如果你想支持該版本(似乎你已經標記了它),然後只顯式別名每列:

WITH t AS (
    SELECT RM_LIVE.EMPLOYEE.EMPNO, 
     RM_LIVE.EMPNAME.FIRSTNAME AS EMPFIRSTNAME, 
     RM_LIVE.EMPNAME.LASTNAME AS EMPLASTNAME, 
     RM_LIVE.CRWBASE.BASE, 
     RM_LIVE.CRWCAT.crwcat AS CAT, 
     RM_LIVE.CRWSPECFUNC.IDCRWSPECFUNC AS CODE