Исходя из вашего описания, шаблон регулярного выражения должен быть
'^(C0[5-9]|A[0-8][0-9]|A9[0-7])'
. ^
привязывает начало значения, а круглые скобки позволяют сопоставить любой из разделенных конвейерами шаблонов;и шаблоны упрощаются, поскольку A00-A89 могут обрабатываться за один раз.
Это помечает одну строку с вашим исходным запросом.Следующий этап - переместить это в подзапрос, а затем использовать аналитическую функцию, разбитую на p_num
, которую вы хотите использовать в общем виде:
max(found_code) over (partition by p_num)
Таким образом, это становится (с дополнительными строками для соответствиядругое правило):
with table1 (id, p_num, d_id, code) as
(
select 613414470, 1706014200960, 119530, 'D99' from dual union all
select 613414471, 1706014200960, 119531, 'C05' from dual union all
--
select 613414473, 1706014200964, 119539, 'F20.0' from dual union all
select 613414473, 1706014200964, 119539, 'F22.0' from dual union all
select 613415801, 1707045167741, 115182, 'A94.0' from dual union all
select 613415801, 1707045167741, 115182, null from dual union all
select 613417084, 1702038456441, 6541 , 'E79' from dual union all
select 613417084, 1702038456421, 6541 , 'I10' from dual union all
select 613418372, 1706226211517, 25727 , 'F32.9' from dual
)
select id, p_num, d_id, code, max(found_code) over (partition by p_num) as found_code
from (
select t1.*
, case when regexp_like( code, '^(C0[5-9]|A[0-8][0-9]|A9[0-7])' )
then 1
else 0
end as found_code
from table1 t1
);
ID P_NUM D_ID CODE FOUND_CODE
------------- ------------- ------------- ----- -------------
613414470 1706014200960 119530 D99 1
613414471 1706014200960 119531 C05 1
613414473 1706014200964 119539 F20.0 0
613414473 1706014200964 119539 F22.0 0
613415801 1707045167741 115182 A94.0 1
613415801 1707045167741 115182 1
613417084 1702038456441 6541 E79 0
613417084 1702038456421 6541 I10 0
613418372 1706226211517 25727 F32.9 0