PostgreSQL
 sql >> Datenbank >  >> RDS >> PostgreSQL

So erhalten Sie eine Teilzeichenfolge vom vierten Auftreten eines Zeichens bis zum Ende der angegebenen Zeichenfolge in PSQL

Sie können einen regulären Ausdruck verwenden

with example(str) as (
    values('/this/is/a/given/string/test.file')
)

select regexp_replace(str, '(/.*?){4}', '')
from example;

     regexp_replace     
------------------------
 given/string/test.file
(1 row) 

oder die Funktion string_to_array() :

select string_agg(word, '/' order by ord)
from example,
unnest(string_to_array(str, '/')) with ordinality as u(word, ord)
where ord > 4;

Lesen Sie auch So finden Sie das dritte Vorkommen eines Musters auf einer Linie .