Получение определенных строк внутри строки с использованием Oracle SQL - PullRequest
2 голосов
/ 02 февраля 2012

Я пытаюсь выполнить следующий поиск строки с использованием Oracle SQL 11g R2:

Данные:

| CN = aXYZApple-Au, OU = Управляемый, OU = Группы, DC = ядро, DC = dir, DC = abc, DC = com | CN = 31107427, OU = списки рассылки, OU = общий доступ Почтовые ящики, DC = ядро, DC = каталог, DC = abc, DC = com | CN = ea90045052, OU = группы, OU = eProfile, DC = ядро, DC = dir, DC = abc, DC = com | CN = S0901448, OU = списки рассылки, OU = общий доступ Почтовые ящики, DC = ядро, DC = каталог, DC = abc, DC = com | CN = 00900887, OU = Распределение Списки, OU = Общие почтовые ящики, DC = ядро, DC = dir, DC = abc, DC = com | CN = NSMMMM, OU = LRP, OU = Группы, DC = ядро, DC = dir, DC = abc, DC = com | CN = aXYZApple-Readonly, OU = Управляемый, OU = групп, DC = ядро, DC = DIR, DC = азбука, DC = COM | CN = WWSWW-Au, OU = LRP, OU = Группы, DC = ядро, DC = dir, DC = abc, DC = com | CN = aLogical_RW, OU = Управляемый, OU = Группы, DC = ядро, DC = dir, DC = abc, DC = com | CN = aXYZApple-Write, OU = Управляемый, OU = Группы, DC = ядро, DC = dir, DC = abc, DC = com |

Из приведенных выше данных мне нужно получить все строки, содержащие строку "aXYZApple" только с "OU = Managed" в качестве второй части этого совпадения строки.

Таким образом, исходя из вышеизложенного, я получаю следующие результаты, которые будут отображаться только:

aXYZApple-Au
aXYZApple-Readonly
aXYZApple-Write

Я использую Oracle regexp_like / regexp_replace.

1 Ответ

7 голосов
/ 02 февраля 2012

Вы можете использовать regexp_substr, чтобы разбить ваши входные данные на строки, а затем искать соответствующие строки, например:

SQL> SELECT regexp_substr(line, 'aXYZApple[^,]*') subtxt
  2    FROM (SELECT regexp_substr(:x, '[^|]*\|', 1, rownum + 1) line
  3             FROM dual
  4           CONNECT BY LEVEL <= length(:x) - length(REPLACE(:x, '|', '')))
  5   WHERE regexp_substr(line || ',', '[^,]*,', 1, 2) = 'OU=Managed,'
  6     AND line LIKE '%aXYZApple%';

SUBTXT
--------------------------------------------------------------------------------
aXYZApple-Au
aXYZApple-Readonly
aXYZApple-Write

Вот небольшое объяснение. Вы должны пройти запрос шаг за шагом.

Внутренняя часть запроса будет перебирать ваши данные (для каждого |):

SQL> SELECT regexp_substr(:x, '[^|]*\|', 1, rownum + 1) line
  2    FROM dual
  3  CONNECT BY LEVEL <= length(:x) - length(REPLACE(:x, '|', ''));

LINE
--------------------------------------------------------------------------------
 CN=aXYZApple-Au,OU=Managed,OU=Groups,DC=core,DC=dir,DC=abc,DC=com |
 CN=31107427,OU=Distribution Lists,OU=Shared Mailboxes,DC=core,DC=dir,DC=abc,DC=
 CN=ea90045052,OU=Groups,OU=eProfile,DC=core,DC=dir,DC=abc,DC=com |
 CN=S0901448,OU=Distribution Lists,OU=Shared Mailboxes,DC=core,DC=dir,DC=abc,DC=
 CN=00900887,OU=Distribution Lists,OU=Shared Mailboxes,DC=core,DC=dir,DC=abc,DC=
 CN=NSMMMM,OU=LRP,OU=Groups,DC=core,DC=dir,DC=abc,DC=com |
 CN=aXYZApple-Readonly,OU=Managed,OU=Groups,DC=core,DC=dir,DC=abc,DC=com |
 CN=WWSWW-Au,OU=LRP,OU=Groups,DC=core,DC=dir,DC=abc,DC=com |
 CN=aLogical_RW,OU=Managed,OU=Groups,DC=core,DC=dir,DC=abc,DC=com |
 CN=aXYZApple-Write,OU=Managed,OU=Groups,DC=core,DC=dir,DC=abc,DC=com |

Затем вы должны выполнить цикл для строки OU=Managed во второй позиции:

SQL> SELECT regexp_substr(line || ',', '[^,]*,', 1, 2) second_part
  2    FROM (SELECT regexp_substr(:x, '[^|]*\|', 1, rownum + 1) line
  3             FROM dual
  4           CONNECT BY LEVEL <= length(:x) - length(REPLACE(:x, '|', '')));

SECOND_PART
--------------------------------------------------------------------------------
OU=Managed,
OU=Distribution Lists,
OU=Groups,
OU=Distribution Lists,
OU=Distribution Lists,
OU=LRP,
OU=Managed,
OU=LRP,
OU=Managed,
OU=Managed,

Наконец, выберите соответствующую деталь с последним regexp_substr.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...