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

Čtenářům AbcLinuxu vše nejlepší k dnešnímu Dni zvýšení povědomí o tučňácích (Penguin Awareness Day).

Ladislav Hagara | Komentářů: 0
dnes 06:00 | Komunita

Bylo spuštěno hlasování o přednáškách a workshopech pro letošní InstallFest, jenž proběhne o víkendu 4. a 5. března v Praze. Současně byla oznámena změna místa. InstallFest se letos vrací zpět na Karlovo náměstí do budovy E.

Ladislav Hagara | Komentářů: 0
dnes 02:48 | Komunita

Greg Kroah-Hartman potvrdil, že Linux 4.9 je jádrem s prodlouženou upstream podporou (LTS, Long Term Support). Podpora je plánována do ledna 2019. Aktuální jádra s prodlouženou podporou jsou tedy 3.2, 3.4, 3.10, 3.12, 3.16, 3.18, 4.1, 4.4 a 4.9.

Ladislav Hagara | Komentářů: 0
dnes 00:11 | Zajímavý článek

Výrobce síťových prvků, společnost Netgear, spustila nový program, který slibuje vývojářům, expertům, ale i běžným uživatelům vyplacení finanční odměny za nalezení bezpečnostních chyby v jejich produktech. Za nalezení zranitelnosti v hardware, API nebo mobilní aplikaci nabízí odměnu od 150 do 15 tisíc dolarů (dle závažnosti).

Michal Makovec | Komentářů: 0
dnes 00:08 | Pozvánky

V sobotu 18. 2. se v Praze v prostorách VŠE uskuteční od 9:30 již 4. ročník největší české konference o open source redakčním systému WordPress (WP) - WordCamp Praha 2017.

… více »
smíťa | Komentářů: 0
včera 23:58 | Komunita

Kryptoměnová komunita zahájila nový rok spuštěním projektu Blockchain.cz, jehož cílem je kolektivně nalézt ideální překlad pro čím dál frekventovanější slovo „blockchain“. Přispět návrhem může kdokoli. Sběr bude trvat až do konce září 2017. Následně bude probíhat dvoutýdenní veřejné hlasování, které bude zakončeno výběrem toho nejlepšího návrhu.

xHire | Komentářů: 5
včera 15:55 | Bezpečnostní upozornění

Společnost Oracle vydala čtvrtletní bezpečnostní aktualizaci svých softwarových produktů (CPU, Critical Patch Update). Opraveno je celkově 270 bezpečnostních chyb. V Oracle Java SE je například opraveno 17 bezpečnostních chyb. Vzdáleně zneužitelných bez autentizace je 16 z nich. V Oracle MySQL je opraveno 27 bezpečnostních chyb. Vzdáleně zneužitelných bez autentizace je 5 z nich.

Ladislav Hagara | Komentářů: 0
včera 02:48 | Nová verze

Po půl roce od vydání verze 9.0 (zprávička) byla vydána verze 10.0 zvukového serveru PulseAudio. Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 27
včera 00:33 | Komunita Ladislav Hagara | Komentářů: 8
18.1. 17:30 | Zajímavý článek

Mozilla.cz informuje, že webový prohlížeč Firefox bude od verze 53 obsahovat integrovaný prohlížeč dat ve formátu JSON. Firefox kromě strukturovaného prohlížení nabídne také možnost filtrace a uložení na disk. Dle plánu by měl Firefox 53 vyjít 18. 4. 2017.

Ladislav Hagara | Komentářů: 1
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (74%)
 (3%)
 (11%)
Celkem 332 hlasů
 Komentářů: 24, poslední 17.1. 10:14
    Rozcestník
    Reklama

    Dotaz: SQL select case

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

    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: 66 | 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: 66 | 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: 66 | 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.