Slå in värdet i avgränsaren du använder i den avgränsade listan och kontrollera sedan om det är en understräng till den avgränsade listan (även med avgränsningstecknen omsluten):
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;
Jag måste behålla logiken i whereClausen
Verkligen, inte. Ovanstående fråga kommer att vara mycket effektivare.
Men om du måste då:
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, '[^,]+' )
);