Jak načíst string po "=" v multi řádku, sloupci hodnotu pomocí oracle sql?

0

Otázka

Mám tabulku se sloupci s multi-line hodnotu a každý řádek je druh hodnota dvojice klíč (odděleny znakem = a pravděpodobně končí s nový řádek přestávky)

Příklad hodnota v jedné buňce ve sloupci:

Seznam pár klíč-hodnota
key00=value00 <\n> key01=value01 <\n> key02=value02

Hledám SQL (Oracle) dotaz najít konkrétní klíč (řekněme Key01) a zobrazí v následujícím formátu

KLÍČ HODNOTA
Key01 Value01

Prosím, pomozte.

oracle sql
2021-11-24 05:28:58
1

Nejlepší odpověď

0

Tady je jedna možnost

Ukázková data:

SQL> select * from test;

        ID COL
---------- --------------------------------------------------
         1 key00=value00
           key01=value01
           key02=value02

Poddotaz vrátí řetězec, který začíná na "klíč" hodnota (předán jako parametr), zatímco vnější dotaz rozdělí to řetězec na klíč a hodnotu sami:

SQL> select regexp_substr(str, '^\w+') key,
  2         regexp_substr(str, '\w+$') value
  3  from (select regexp_substr(col, '&par_key=\w+') str
  4        from test
  5       );
Enter value for par_key: key01

KEY             VALUE
--------------- ---------------
key01           value01

SQL>
2021-11-24 07:13:22

V jiných jazycích

Tato stránka je v jiných jazycích

Русский
..................................................................................................................
Italiano
..................................................................................................................
Polski
..................................................................................................................
Română
..................................................................................................................
한국어
..................................................................................................................
हिन्दी
..................................................................................................................
Français
..................................................................................................................
Türk
..................................................................................................................
Português
..................................................................................................................
ไทย
..................................................................................................................
中文
..................................................................................................................
Español
..................................................................................................................
Slovenský
..................................................................................................................