Я работаю в Oracle и пытаюсь выполнить хранимую процедуру для GET данных.
Я хочу вставить случай, когда внутри WHERE
, но он не компилирует меняи мне возвращаются следующие ошибки:
- Ошибка (11.5): PL / SQL: оператор SQL игнорируется
- Ошибка (22.37): PL / SQL: ORA-00905: отсутствуетключевое слово
Это процедура:
create or replace PROCEDURE SP_S_DETTAGLIOLOTTI
(
DATAINIZIO IN VARCHAR2,
DATAFINE IN VARCHAR2,
CODICEPROFILO IN NUMBER,
dett_lotti OUT SYS_REFCURSOR
)
AS
BEGIN
OPEN dett_lotti FOR
SELECT A.IDLOTTO as IDLOTTO, B.S_DENOMINAZIONE as PROFILOLOTTO, A.TOTRKD as TOTALERECORD,
CASE WHEN A.DATRPAPSA IS NULL
THEN 'NO'
ELSE 'SI'
END AS ELABORATO
FROM DLTOPST A
INNER JOIN REQUISITI B
ON A.COD_REQUISITO = B.COD_REQUISITI
WHERE
CASE WHEN DATAINIZIO IS NOT NULL AND CODICEPROFILO IS NULL
THEN DATA_INVIO_POSTEL BETWEEN TO_DATE(DATAINIZIO, 'DD/MM/YYYY HH24.MI.SS')
AND TO_DATE(DATAFINE, 'DD/MM/YYYY HH24.MI.SS')
WHEN DATAINIZIO IS NOT NULL AND CODICEPROFILO IS NOT NULL
THEN DATA_INVIO_POSTEL BETWEEN TO_DATE(DATAINIZIO, 'DD/MM/YYYY HH24.MI.SS')
AND TO_DATE(DATAFINE, 'DD/MM/YYYY HH24.MI.SS') AND COD_REQUISITO = CODICEPROFILO
ELSE COD_REQUISITO = CODICEPROFILO
END ;
END SP_S_DETTAGLIOLOTTI;
где я ошибаюсь?