Supponendo che il tuo carattere di interruzione di riga sia CHR(10), qualcosa come il seguente dovrebbe funzionare:
SELECT TRIM(REGEXP_REPLACE(addr, '(.*)' || CHR(10) || '.*' || CHR(10) || '.*', '\1')) AS STREET_ADDR,
TRIM(REGEXP_REPLACE(addr, '.*' || CHR(10) || '(.*)' || CHR(10) || '.*', '\1')) AS CITY,
TRIM(REGEXP_REPLACE(addr, '.*' || CHR(10) || '.*' || CHR(10) || '(.*)', '\1')) AS STATE
FROM addr_table;
Se addr_table viene popolato utilizzando la seguente istruzione:
INSERT INTO addr_table(addr)
VALUES('12345 MY STREET' || CHR(10) || 'NOWHERESVILLE' || CHR(10) || 'ASTATE');
il precedente SELECT tornerà
STREET_ADDR CITY STATE
12345 MY STREET NOWHERESVILLE ASTATE
Condividi e divertiti