sql >> Databáze >  >> RDS >> Oracle

Regulární výraz Oracle rozdělil řetězec od posledního výskytu

Můžete to udělat bez dvojitého obrácení extrahováním různých skupin zachycení (obklopených kruhem () závorky):

WITH t ( VAL ) AS (
  SELECT 'my_new_table_2015_06_31' FROM DUAL UNION ALL
  SELECT 'my_new_table_temp_2016_06_31' FROM DUAL
)
SELECT REGEXP_SUBSTR( val, '^(.*)_([^_]+)_([^_]+)_([^_]+)$', 1, 1, NULL, 1 ) AS COL4,
       REGEXP_SUBSTR( val, '^(.*)_([^_]+)_([^_]+)_([^_]+)$', 1, 1, NULL, 2 ) AS COL3,
       REGEXP_SUBSTR( val, '^(.*)_([^_]+)_([^_]+)_([^_]+)$', 1, 1, NULL, 3 ) AS COL2,
       REGEXP_SUBSTR( val, '^(.*)_([^_]+)_([^_]+)_([^_]+)$', 1, 1, NULL, 4 ) AS COL1
FROM   t

Regulární výraz můžete dokonce mnohem zjednodušit pomocí:

'^(.+)_(.+)_(.+)_(.+)$'

První .+ je chamtivý, takže se bude co nejvíce shodovat, dokud nezbude dostatek řetězce pro minimální počet shod ve 2. - 4. zachytávací skupině.

Nepotřebujete však regulární výrazy :

WITH t ( VAL ) AS (
  SELECT 'my_new_table_2015_06_31' FROM DUAL UNION ALL
  SELECT 'my_new_table_temp_2016_06_31' FROM DUAL
)
SELECT SUBSTR( val, 1,        pos1 - 1        ) AS col4,
       SUBSTR( val, pos1 + 1, pos2 - pos1 - 1 ) AS col3,
       SUBSTR( val, pos2 + 1, pos3 - pos2 - 1 ) AS col2,
       SUBSTR( val, pos3 + 1                  ) AS col1
FROM   (
  SELECT val,
         INSTR( val, '_', -1, 1 ) AS pos3,
         INSTR( val, '_', -1, 2 ) AS pos2,
         INSTR( val, '_', -1, 3 ) AS pos1
  FROM   t
);


  1. Jak napsat efektivní počítadlo návštěv pro webové stránky

  2. Profilování dotazů 101 – Ano, skutečně může zlepšit výkon vašeho SQL serveru

  3. TO_SECONDS() Příklady – MySQL

  4. Jak AUTO aktualizovat MySQL po vypršení platnosti pole časového razítka