sql >> Databáze >  >> RDS >> Oracle

SQL k vyhledání slov s velkými písmeny ve sloupci

Toto by mohl být způsob:

-- a test case
with test(id, str) as (
select 1, 'This is a EXAMPLE' from dual union all
select 2, 'This is a TEST' from dual union all
select 3, 'This is a VALUE' from dual union all
select 4, 'This IS aN EXAMPLE' from dual
)
-- concatenate the resulting words
select id, listagg(str, ' ') within group (order by pos)
from (
    -- tokenize the strings by using the space as a word separator
    SELECT id,
           trim(regexp_substr(str, '[^ ]+', 1, level)) str,
           level as pos           
      FROM test t
    CONNECT BY instr(str, ' ', 1, level - 1) > 0
      and prior id = id
      and prior sys_guid() is not null
    )
-- only get the uppercase words
where regexp_like(str, '^[A-Z]+$')   
group by id

Cílem je tokenizovat každý řetězec, pak odříznout slova, která nejsou tvořena velkými písmeny, a poté zřetězit zbývající slova.

Výsledek:

1    EXAMPLE
2    TEST
3    VALUE
4    IS EXAMPLE

Pokud potřebujete zpracovat nějaký jiný znak jako velké písmeno, můžete upravit where podmínka pro filtrování odpovídajících slov; například s '_':

with test(id, str) as (
select 1, 'This is a EXAMPLE' from dual union all
select 2, 'This is a TEST' from dual union all
select 3, 'This is a VALUE' from dual union all
select 4, 'This IS aN EXAMPLE' from dual union all
select 5, 'This IS AN_EXAMPLE' from dual
)
select id, listagg(str, ' ') within group (order by pos)
from (
    SELECT id,
           trim(regexp_substr(str, '[^ ]+', 1, level)) str,
           level as pos           
      FROM test t
    CONNECT BY instr(str, ' ', 1, level - 1) > 0
      and prior id = id
      and prior sys_guid() is not null
    )
where regexp_like(str, '^[A-Z_]+$')   
group by id

dává:

1   EXAMPLE
2   TEST
3   VALUE
4   IS EXAMPLE
5   IS AN_EXAMPLE


  1. SQL Server, převést pojmenovanou instanci na výchozí instanci?

  2. Převést Unixtime na Datetime SQL (Oracle)

  3. Jak získat kalendářní čtvrtletí z data v TSQL

  4. Primární klíč v SQL:Vše, co potřebujete vědět o operacích primárního klíče