abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 18:00 | IT novinky

    DuckDuckGo AI Chat umožňuje "pokecat si" s GPT-3.5 Turbo od OpenAI nebo Claude 1.2 Instant od Anthropic. Bez vytváření účtu. Všechny chaty jsou soukromé. DuckDuckGo je neukládá ani nepoužívá k trénování modelů umělé inteligence.

    Ladislav Hagara | Komentářů: 0
    dnes 14:22 | IT novinky

    VASA-1, výzkumný projekt Microsoftu. Na vstupu stačí jediná fotka a zvukový záznam. Na výstupu je dokonalá mluvící nebo zpívající hlava. Prý si technologii nechá jenom pro sebe. Žádné demo, API nebo placená služba. Zatím.

    Ladislav Hagara | Komentářů: 2
    dnes 04:44 | Nová verze

    Nová čísla časopisů od nakladatelství Raspberry Pi: MagPi 140 (pdf) a HackSpace 77 (pdf).

    Ladislav Hagara | Komentářů: 0
    dnes 01:00 | Nová verze

    ESPHome, tj. open source systém umožňující nastavovat zařízení s čipy ESP (i dalšími) pomocí konfiguračních souborů a připojit je do domácí automatizace, například do Home Assistantu, byl vydán ve verzi 2024.4.0.

    Ladislav Hagara | Komentářů: 0
    včera 22:11 | IT novinky Ladislav Hagara | Komentářů: 0
    včera 20:55 | Nová verze

    Neziskové průmyslové konsorcium Khronos Group vydalo verzi 1.1 specifikace OpenXR (Wikipedie), tj. standardu specifikujícího přístup k platformám a zařízením pro XR, tj. platformám a zařízením pro AR (rozšířenou realitu) a VR (virtuální realitu). Do základu se z rozšíření dostalo XR_EXT_local_floor. Společnost Collabora implementuje novou verzi specifikace do platformy Monado, tj. open source implementace OpenXR.

    Ladislav Hagara | Komentářů: 2
    včera 17:22 | Nová verze

    Byla vydána nová verze 0.38.0 multimediálního přehrávače mpv (Wikipedie) vycházejícího z přehrávačů MPlayer a mplayer2. Přehled novinek, změn a oprav na GitHubu. Požadován je FFmpeg 4.4 nebo novější a také libplacebo 6.338.2 nebo novější.

    Ladislav Hagara | Komentářů: 13
    včera 17:11 | Nová verze

    ClamAV (Wikipedie), tj. multiplatformní antivirový engine s otevřeným zdrojovým kódem pro detekci trojských koní, virů, malwaru a dalších škodlivých hrozeb, byl vydán ve verzích 1.3.1, 1.2.3 a 1.0.6. Ve verzi 1.3.1 je mimo jiné řešena bezpečnostní chyba CVE-2024-20380.

    Ladislav Hagara | Komentářů: 2
    včera 12:11 | IT novinky

    Digitální a informační agentura (DIA) oznámila (PDF, X a Facebook), že mobilní aplikace Portál občana je ode dneška oficiálně venku.

    Ladislav Hagara | Komentářů: 10
    včera 05:11 | Komunita

    #HACKUJBRNO 2024, byly zveřejněny výsledky a výstupy hackathonu města Brna nad otevřenými městskými daty, který se konal 13. a 14. dubna 2024.

    Ladislav Hagara | Komentářů: 2
    KDE Plasma 6
     (68%)
     (10%)
     (2%)
     (20%)
    Celkem 565 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Dotaz: SQL select case

    20.3.2010 19:46 Juro
    SQL select case
    Přečteno: 1664×

    potreboval by som pomoct s nasledujucim:

    mam tabulku:

    CREATE TABLE test
    (number INTEGER NOT NULL,
    string VARCHAR(255) NOT NULL,
    count INTEGER,
    UNIQUE(number), UNIQUE(string))
    

    a potrebujem vytvorit sql query, ktora vrati:

    - 1, ak je tabulka prazdna,
    - number z riadka, v ktorom sa zhoduje nejaky retazec s retazcom zo stlpca string
    - number z riadka, v ktorom je count == 0
    - max(count) + 1 inak
    

    moj pokus:

    SELECT CASE
    WHEN (COUNT(*) = 0) THEN 1
    WHEN (string = ?) THEN (SELECT number FROM test WHERE string = ?)
    WHEN (MIN(count) = 0) THEN (SELECT number FROM test WHERE count = 0)
    ELSE (MAX(number) + 1) END
    FROM test
    

    pre tabulku s hodnotami:

    1 | aaa | 1
    2 | bbb | 1
    3 | ccc | 1
    4 | ddd | 1
    

    nefunguje spravne, ked pre retazec 'aaa' vrati 5 namiesto 1, ale pre retazec 'ddd' uz vrati spravny vysledok (4)

    Dakujem za rady

    Odpovědi

    20.3.2010 20:19 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: SQL select case
    Takhle ten dotaz nemůže fungovat, protože vnořené dotazy se provádějí znova na celé tabulce. Navíc by vám tenhle dotaz vrátil tolik řádků, kolik jich je v tabulce test. O jakou se jedná databázi?

    Můžete zkusit něco takového, ale podle databáze by se to nejspíš dalo napsat jinak a lépe:
    
    SELECT
      COALESCE(
        CASE WHEN (COUNT(t1.*) = 0) THEN 1 ELSE NULL END,
        CASE WHEN (COUNT(t2.*) > 0) THEN t2.number ELSE NULL END,
        CASE WHEN (COUNT(t3.*) > 0) THEN t3.number ELSE NULL END,
        SELECT MAX(number) FROM test
      )
    FROM test t1, test t2, test t3
    WHERE
      t2.string = ? AND
      t3.count = 0
    
    Každopádně ta vaše třetí podmínka (number z řádku, kde count == 0) může být splněna pro víc řádků.
    20.3.2010 20:39 Juro
    Rozbalit Rozbalit vše Re: SQL select case
    dakujem za odpoved, jedna sa o sqlite3. To, ze number z riadku kde count == 0 moze byt splnena viac krat nevadi, staci ked mi vrati jednu hodnotu, nezalezi ktoru.
    20.3.2010 21:16 Juro
    Rozbalit Rozbalit vše Re: SQL select case
    Pokusam sa ten Vas sql dotaz v sqlite rozchodit, ale zatial bez uspechu - dostavam iba syntax errory. Je to vobec mozne do sqlite syntaxe prepisat?
    20.3.2010 22:13 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: SQL select case
    Nevím, SQLite neznám.
    20.3.2010 22:34 Tomáš
    Rozbalit Rozbalit vše Re: SQL select case
    Myslím, že toto řešení nemůže v žádném případě fungovat. Úvaha proč to takto nemůže fungovat je následující: Pokud uděláte agregaci ( funkce count ) tak už ve výsledku nemáte pole t2.number a t3.number. Asi bych to napsal takto:
    
    select 
      coalesce( case when A.cnt = 0 then 1 end , B.num,C.num,A.cnt+1 )
    from
      (select count(*) as cnt from test ) as A
      ,(select max(number) as num from test where string = 'retez') as B
      ,(select max(number) as num from test where "count" = 0 ) as C 
    

    IMHO je hodně nešťastné pojmenovat pole count, protože toto jméno koliduje se jménem funkce.

    BTW tak jak to popsal autor dotazu to nemůže být, protože není jasné jaké number se má vrátit, pokud je count == 0 pro vícero řádků? V mém řešení jsem zvolil to největší.

    21.3.2010 10:11 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: SQL select case
    Máte pravdu. Přemýšlel jsem, jestli použít vnořené dotazy, nebo to zkusit udělat přes normální spojení tabulek, a ta druhá varianta mi připadala schůdnější pro víc databází, ale neuvědomil jsem si ten problém s agregační funkcí.

    Založit nové vláknoNahoru

    Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

    ISSN 1214-1267   www.czech-server.cz
    © 1999-2015 Nitemedia s. r. o. Všechna práva vyhrazena.