2016-04-28 6 views
0

Я выполняю этот запрос в оракуле, и он дает мне ошибку пропущенных правильных круглых скобок в строке 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'? Это синтаксис из другой СУБД? И что такое '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 
Смежные вопросы