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í
×
    včera 22:00 | Komunita

    V červenci loňského roku organizace Apache Software Foundation (ASF) oznámila, že se částečně přestane dopouštět kulturní apropriace a změní své logo. Dnes bylo nové logo představeno. "Indiánské pírko" bylo nahrazeno dubovým listem a text Apache Software Foundation zkratkou ASF. Slovo Apache se bude "zatím" dál používat. Oficiální název organizace zůstává Apache Software Foundation, stejně jako názvy projektů, například Apache HTTP Server.

    Ladislav Hagara | Komentářů: 3
    včera 17:33 | Nová verze

    Byla vydána (𝕏) srpnová aktualizace aneb nová verze 1.104 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.104 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    včera 15:33 | IT novinky

    Spotify spustilo přehrávání v bezztrátové kvalitě. V předplatném Spotify Premium.

    Ladislav Hagara | Komentářů: 0
    včera 15:00 | IT novinky

    Spoluzakladatel a předseda správní rady americké softwarové společnosti Oracle Larry Ellison vystřídal spoluzakladatele automobilky Tesla a dalších firem Elona Muska na postu nejbohatšího člověka světa. Hodnota Ellisonova majetku díky dnešnímu prudkému posílení ceny akcií Oraclu odpoledne vykazovala nárůst o více než 100 miliard dolarů a dosáhla 393 miliard USD (zhruba 8,2 bilionu Kč). Hodnota Muskova majetku činila zhruba 385 miliard dolarů.

    Ladislav Hagara | Komentářů: 1
    10.9. 21:22 | Nová verze

    Bylo vydáno Eclipse IDE 2025-09 aneb Eclipse 4.37. Představení novinek tohoto integrovaného vývojového prostředí také na YouTube.

    Ladislav Hagara | Komentářů: 0
    10.9. 18:22 | IT novinky

    T-Mobile od 15. září zpřístupňuje RCS (Rich Communication Services) zprávy i pro iPhone.

    Ladislav Hagara | Komentářů: 3
    10.9. 13:22 | IT novinky

    Společnost ARM představila platformu Arm Lumex s Arm C1 CPU Cluster a Arm Mali G1-Ultra GPU pro vlajkové chytré telefony a počítače nové generace.

    Ladislav Hagara | Komentářů: 0
    10.9. 05:44 | Nová verze

    Unicode Consortium, nezisková organizace koordinující rozvoj standardu Unicode, oznámila vydání Unicode 17.0. Přidáno bylo 4 803 nových znaků. Celkově jich je 159 801. Přibylo 7 nových Emoji.

    Ladislav Hagara | Komentářů: 0
    9.9. 21:00 | IT novinky Ladislav Hagara | Komentářů: 17
    9.9. 18:33 | Nová verze

    Realtimová strategie Warzone 2100 (Wikipedie) byla vydána ve verzi 4.6.0. Podrobný přehled novinek, změn a oprav v ChangeLogu na GitHubu. Nejnovější verzi Warzone 2100 lze již instalovat také ze Snapcraftu a Flathubu.

    Ladislav Hagara | Komentářů: 1
    Pro otevření více webových stránek ve webovém prohlížečí používám
     (83%)
     (7%)
     (2%)
     (2%)
     (4%)
     (2%)
    Celkem 164 hlasů
     Komentářů: 12, poslední 10.9. 13:00
    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: 401×

    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.