Zawiń wartość w separator, którego używasz, w rozdzielaną listę, a następnie sprawdź, czy jest to podłańcuch listy rozdzielanej (również z otaczającymi ją ogranicznikami):
SELECT r.Value
FROM AD_Ref_List r
INNER JOIN xx_insert x
ON ( ',' || x.XX_DocAction_Next || ',' LIKE '%,' || r.value || ',%' )
WHERE r.AD_Reference_ID = 1000448
AND x.xx_insert_id = 1000283;
muszę zachować logikę w klauzuli whereClause
Naprawdę nie. Powyższe zapytanie będzie znacznie wydajniejsze.
Ale jeśli musisz, to:
SELECT Value
FROM AD_Ref_List
WHERE AD_Reference_ID = 1000448
AND value IN (
SELECT REGEXP_SUBSTR( XX_DocAction_Next, '[^,]+', 1, LEVEL )
FROM xx_insert
WHERE xx_insert_id = 1000283
CONNECT BY LEVEL <= REGEXP_COUNT( XX_DocAction_Next, '[^,]+' )
);