INSTR(ltrim(pn.pname),'REFERENCE ID=')
zwraca 0 (wskazując, że poszukiwany podciąg nie został znaleziony) i jeśli spróbujesz to zrobić:
REGEXP_SUBSTR( value, regex, 0 )
Pojawi się błąd:
ORA-01428: argument '0' is out of range
Zamiast tego możesz użyć:
REGEXP_SUBSTR(
pn.pname,
'REFERENCE ID="(\d+)"',
1, -- Start from the 1st character
1, -- Find the 1st occurrence
NULL, -- No flags
1 -- Return the contents of the 1st capturing group
)