powered by simpleCommunicator - 2.0.61     © 2026 Programmizd 02
Целевая тема:
Создать новую тему:
Автор:
Закрыть
Цитировать
Форумы / Oracle [игнор отключен] [закрыт для гостей] / регулярные выражения
2 сообщений из 2, страница 1 из 1
регулярные выражения
    #39493115
oled_eas
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Гость
Привет,
Собственно есть некий путь, который хранится в виде строки
Код: plsql
1.
  p_element_path := 'ffgfg:45454|fdfd:511|00|mck:9';


Надо убрать из этой строки все, что идет до двоеточия включительно.
Т.е. в данном примере должно быть
45454|511|00|9, а у меня получается 45454|511|9.
Смог разобраться тока как убрать двоеточия и текст до него.
Проблема с данными типа как |00 --их он не включает в выборку, ибо двоеточия нет.
Может кто подскажет навскидку, что дописать\переписать?
Или может вообще убрать проверку на двоеточия, но тогда, я не знаю как вообще реализовывать.

Код: plsql
1.
2.
3.
4.
5.
6.
7.
8.
9.
10.
11.
12.
13.
14.
15.
declare 
p_element_path varchar2(4000);
p_element_path_new varchar2(4000);
cnt number := 0;
begin
  p_element_path := 'ffgfg:45454|fdfd:511|00|mck:9';
  for i in (SELECT REGEXP_SUBSTR(p_element_path, '[^|;]+', REGEXP_INSTR(p_element_path, '[^:;]+',1, LEVEL, 0), 1) a1
  FROM DUAL
  CONNECT BY REGEXP_INSTR(p_element_path, '[^:;]+', 1, LEVEL) > 0) loop
  cnt:= cnt+1;
  if cnt >1 then
     p_element_path_new:= p_element_path_new||'|'||i.a1;
  end if;
  end loop;
end;      
...
Рейтинг: 0 / 0
регулярные выражения
    #39493120
Фотография andrey_anonymous
Скрыть профиль Поместить в игнор-лист Сообщения автора в теме
Участник
Код: plsql
1.
2.
3.
with t as (select 'ffgfg:45454|fdfd:511|00|mck:9' str from dual)
select str, regexp_replace(str,'[^:|]*:') s2
from t
...
Рейтинг: 0 / 0
2 сообщений из 2, страница 1 из 1
Форумы / Oracle [игнор отключен] [закрыт для гостей] / регулярные выражения
Найденые пользователи ...
Разблокировать пользователей ...
Читали форум (0):
Пользователи онлайн (0):
x
x
Закрыть


Просмотр
0 / 0
Close
Debug Console [Select Text]