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

Remplacer une partie du champ par les valeurs de la requête

Peut-être pas le plus efficace, mais il fonctionne de manière récursive (c'est-à-dire si le crit_description contient lui-même des "espaces réservés", ceux-ci sont également développés. (Une première solution, plus simple que ce qui est montré ci-dessous, n'a pas fait cette étape récursive.) Voir le troisième exemple d'entrée que j'ai ajouté. Je posterai à nouveau plus tard si je peux le nettoyer un peu plus.

REMARQUE :Cela suppose que tous les "espaces réservés" se trouvent réellement dans le criteria_info table; Je n'ai pas testé ce qui se passe s'ils ne sont pas trouvés. OP pour indiquer l'exigence.

with
     inputs ( criteria ) as (
       select '$1 = True' from dual union all
       select '$2 > $3'   from dual union all
       select '$1 = $4'   from dual
     ),
     criteria_info ( crit_id, crit_description ) as (
       select 1, 'Example 1' from dual union all
       select 2, 'Example 2' from dual union all
       select 3, 'Example 3' from dual union all
       select 4, '$2 + $3'   from dual
     ),
     rec ( criteria, new_str ) as (
       select  criteria, criteria
         from  inputs        
       union all       
       select  r.criteria, 
               regexp_replace(r.new_str, '\$\d+', c.crit_description, 1, 1)
         from  rec r inner join criteria_info c
               on to_number(regexp_substr(r.new_str, '\$(\d+)', 1, 1, null, 1)) = c.crit_id
         where regexp_substr(r.new_str, '\$\d+') is not null
     )
select criteria, new_str
from   rec
where  regexp_substr(new_str, '\$\d+') is null
;


CRITERIA  NEW_STR
--------- ------------------------------------
$1 = True Example 1 = True
$2 > $3   Example 2 > Example 3
$1 = $4   Example 1 = Example 2 + Example 3

3 rows selected.