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

ORACLE - regexp_substr pro vrácení hodnot null

@Gary_W napsal o problém s použitím tohoto vzoru regulárních výrazů k rozdělení řetězců právě kvůli tomu, jak zachází s prázdnými značkami. (A je na misi... )

Alternativní přístup v tomto příspěvku funguje i zde, s oddělovačem potrubí uniklým:

with t (str) as (
  select '1|CAT|DOG' from dual
  union all select '3|HARRY|GOAT|STACK' from dual
  union all select '6||LION|TIGER' from dual
)
select str, regexp_substr(str, '(.*?)(\||$)', 1, 2, null, 1) from t;

STR                REGEXP_SUBSTR(STR,
------------------ ------------------
1|CAT|DOG          CAT               
3|HARRY|GOAT|STACK HARRY             
6||LION|TIGER                        

Podobně pro třetí prvek:

select str, regexp_substr(str, '(.*?)(\||$)', 1, 3, null, 1) from t;

STR                REGEXP_SUBSTR(STR,
------------------ ------------------
1|CAT|DOG          DOG               
3|HARRY|GOAT|STACK GOAT              
6||LION|TIGER      LION              

A za čtvrté:

select str, regexp_substr(str, '(.*?)(\||$)', 1, 4, null, 1) from t;

STR                REGEXP_SUBSTR(STR,
------------------ ------------------
1|CAT|DOG                            
3|HARRY|GOAT|STACK STACK             
6||LION|TIGER      TIGER             


  1. Zkopírujte řádek, ale s novým ID

  2. Oracle Regexp selže v SQL

  3. Jaká DB pro velké databáze?

  4. optimalizace mysql NENÍ V DOTAZU