Oracle
 sql >> Base de données >  >> RDS >> Oracle

ORACLE - regexp_substr pour renvoyer des valeurs nulles

@Gary_W a écrit sur le problème avec l'utilisation de ce modèle regex pour diviser les chaînes, précisément à cause de la façon dont il traite les balises vides. (Et est en mission... )

L'approche alternative dans ce message fonctionne ici aussi, avec le délimiteur de tube échappé :

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                        

De même pour le troisième élément :

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              

Et le quatrième :

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