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 14:44 | Nová verze

    Byla vydána verze 4.0.0 programovacího jazyka Ruby (Wikipedie). S Ruby Box a ZJIT. Ruby lze vyzkoušet na webové stránce TryRuby. U příležitosti 30. narozenin, první veřejná verze Ruby 0.95 byla oznámena 21. prosince 1995, proběhl redesign webových stránek.

    Ladislav Hagara | Komentářů: 0
    včera 02:11 | Komunita

    Všem čtenářkám a čtenářům AbcLinuxu krásné Vánoce.

    Ladislav Hagara | Komentářů: 17
    včera 02:00 | Nová verze

    Byla vydána nová verze 7.0 linuxové distribuce Parrot OS (Wikipedie). S kódovým názvem Echo. Jedná se o linuxovou distribuci založenou na Debianu a zaměřenou na penetrační testování, digitální forenzní analýzu, reverzní inženýrství, hacking, anonymitu nebo kryptografii. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    23.12. 18:33 | Nová verze

    Vývojáři postmarketOS vydali verzi 25.12 tohoto před osmi lety představeného operačního systému pro chytré telefony vycházejícího z optimalizovaného a nakonfigurovaného Alpine Linuxu s vlastními balíčky. Přehled novinek v příspěvku na blogu. Na výběr jsou 4 uživatelská rozhraní: GNOME Shell on Mobile, KDE Plasma Mobile, Phosh a Sxmo.

    Ladislav Hagara | Komentářů: 0
    23.12. 13:55 | Nová verze

    Byla vydána nová verze 0.41.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 6.1 nebo novější a také libplacebo 6.338.2 nebo novější.

    Ladislav Hagara | Komentářů: 0
    23.12. 12:44 | Nová verze

    Byla vydána nová verze 5.5 (novinky) skriptovacího jazyka Lua (Wikipedie). Po pěti a půl letech od vydání verze 5.4.

    Ladislav Hagara | Komentářů: 0
    22.12. 23:44 | Nová verze

    Byla vydána nová verze 5.4.0 programu na úpravu digitálních fotografií darktable (Wikipedie). Z novinek lze vypíchnout vylepšenou podporu Waylandu. Nejnovější darktable by měl na Waylandu fungovat stejně dobře jako na X11.

    Ladislav Hagara | Komentářů: 0
    21.12. 05:00 | Nová verze

    Byla vydána beta verze Linux Mintu 22.3 s kódovým jménem Zena. Podrobnosti v přehledu novinek a poznámkách k vydání. Vypíchnout lze, že nástroj Systémová hlášení (System Reports) získal mnoho nových funkcí a byl přejmenován na Informace o systému (System Information). Linux Mint 22.3 bude podporován do roku 2029.

    Ladislav Hagara | Komentářů: 2
    21.12. 01:55 | Nová verze

    GNU Project Debugger aneb GDB byl vydán ve verzi 17.1. Podrobný přehled novinek v souboru NEWS.

    Ladislav Hagara | Komentářů: 0
    19.12. 17:22 | IT novinky

    Josef Průša oznámil zveřejnění kompletních CAD souborů rámů tiskáren Prusa CORE One a CORE One L. Nejsou vydány pod obecnou veřejnou licenci GNU ani Creative Commons ale pod novou licencí OCL neboli Open Community License. Ta nepovoluje prodávat kompletní tiskárny či remixy založené na těchto zdrojích.

    Ladislav Hagara | Komentářů: 14
    Kdo vám letos nadělí dárek?
     (33%)
     (2%)
     (11%)
     (2%)
     (1%)
     (2%)
     (15%)
     (19%)
     (14%)
    Celkem 85 hlasů
     Komentářů: 18, poslední včera 15:30
    Rozcestník

    Dotaz: Zotriedenie viacerých stĺpcov podľa podmienky v MySQL

    Bedňa avatar 1.7.2009 10:45 Bedňa | skóre: 34 | blog: Žumpa | Horňany
    Zotriedenie viacerých stĺpcov podľa podmienky v MySQL
    Přečteno: 446×

    Dáta v databáze

    kat1 kat2

    kat3

    ab    
    ad aa  
    ah af ac
    ai ag aj

    Potrebujem výstup

    aa
    ab
    ac
    aj

    Chcem to zotriediť cez MySQL, v PHP by som to vedel, ale musel by som dať viacero dotazou do databázy, čím by sa to celé spomalilo.

    Podmienka znie: Začni na prvom stĺpci s ľava ak sa názov stĺpca nezačína na "kat", tak potom vráť "nokat", ak sa názov stĺpca začína na "kat" pozri sa do stĺpca vpravo (ak sa názov začina na "kat" a je nulový vráť obsah aktuálneho stĺpca) alebo ak (sa názov stĺpca napravo nezačína na "kat" vráť hodnotu aktuálneho stĺpca) inak "čiže ak sa názov stĺpca začína na kat a je nenulový, pozri sa do ďaľšieho stĺpca či sa nezačína na kat a je nenulový prípadne sa stĺpec nezačína na kat" §toto musí bežať v slučke§ vráť hodnotu aktuálneho stĺpca, výsledok zoraď vzostupne podľa abecedy.

     

    KERNEL ULTRAS video channel >>>

    Řešení dotazu:


    Odpovědi

    1.7.2009 11:17 cronin | skóre: 49
    Rozbalit Rozbalit vše Re: Zotriedenie viacerých stĺpcov podľa podmienky v MySQL
    Takýto postup sa dá "našiť" iba na konkrétnu tabuľku, ktorej štruktúru a mená stĺpcov sú dopredu známe. V relačnej databáze totiž neexistuje nič ako úplné usporiadanie stĺpcov tabuľky a vzťah "stĺpec vľavo/vpravo od" nie je definovaný.
    1.7.2009 11:18 Vojtěch Horký | skóre: 39 | blog: Vojtův zápisník | Praha
    Rozbalit Rozbalit vše Re: Zotriedenie viacerých stĺpcov podľa podmienky v MySQL
    Sice jsem úplně přesně nepochopil, jaký systém se má použít, ale pokud jde o to vybírat do výsledku z různých sloupců podle jejich hodnoty, tak by měl jít použít operátor CASE.
    I am always ready to learn although I do not always like to be taught. (W. Churchill)
    1.7.2009 11:44 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Zotriedenie viacerých stĺpcov podľa podmienky v MySQL
    select COALESCE (kat3, kat2, kat1, nokat) from table order by 1;
    Bedňa avatar 1.7.2009 12:10 Bedňa | skóre: 34 | blog: Žumpa | Horňany
    Rozbalit Rozbalit vše Re: Zotriedenie viacerých stĺpcov podľa podmienky v MySQL

    Tá podmienka nebola úplne dobre napísaná takže úprava, ale díky za doterajšie odpovede, možno niečo s toho použijem:
    Ja som to napisal symbolicky, toto potrebujem pretransormovať pre MySQL

    function najdi_ posledny _kat(aktualny() {
      while ((nazov_stlpca(aktualny_stlpec +1) == $left(3,"kat")) AND (obsah_stlpca(aktualny_stlpec +1) != NULL)) {
        aktualny_stlpec++   
       }
        return (obsah_stlpca(aktualny_stlpec)
    }

    if (prvy_stlpec_z_lava != $left(3,"kat")) {
      vysledok = "nokat"
    }
    else {
      if ((nazov_stlpca(aktualny_stlpec +1) == $left(3,"kat")) AND (obsah_stlpca(aktualny_stlpec +1)==NULL)) OR (nazov_stlpca(aktualny_stlpec +1) != $left(3,"kat")) {
        vysledok = obsah_stlpca(aktualny_stlpec)
      }
      else {
        function najdi_posledny_kat(aktualny(aktualny_stlpec)
        vysledok = obsah_stlpca(aktualny_stlpec)
      }
     

    KERNEL ULTRAS video channel >>>
    1.7.2009 13:17 happy barney | skóre: 34 | blog: dont_worry_be_happy
    Rozbalit Rozbalit vše Re: Zotriedenie viacerých stĺpcov podľa podmienky v MySQL
    ak dokážete zabezpečiť, že ak kat(X) je null, tak všetky kat(X+n) sú null (aj nokat), tak sql funkcia COALESCE je to pravé ... btw, v prvom mojom príklade nokat má byť prvý, nie posledný (ako funguje, dočítate sa v manuáli). Ak je počet kat(X) dynamický, treba zmeniť štruktúru.
    Bedňa avatar 1.7.2009 22:03 Bedňa | skóre: 34 | blog: Žumpa | Horňany
    Rozbalit Rozbalit vše Re: Zotriedenie viacerých stĺpcov podľa podmienky v MySQL

    Dík, použijem COALESCE

    KERNEL ULTRAS video channel >>>
    2.7.2009 09:19 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Zotriedenie viacerých stĺpcov podľa podmienky v MySQL
    Pokud můžete změnit strukturu databáze, udělejte to. Sloupce kat1…katN evidentně představují vazbu 1:N a měly by být v samostatné tabulce. Pak se vám s tím bude pracovat mnohem snáz.

    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.