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 15:11 | Bezpečnostní upozornění

    V Redisu byla nalezena a v upstreamu již opravena kritická zranitelnost CVE-2025-49844 s CVSS 10.0 (RCE, vzdálené spouštění kódu).

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

    Ministr a vicepremiér pro digitalizaci Marian Jurečka dnes oznámil, že přijme rezignaci ředitele Digitální a informační agentury Martina Mesršmída, a to k 23. říjnu 2025. Mesršmíd nabídl svou funkci během minulého víkendu, kdy se DIA potýkala s problémy eDokladů, které některým občanům znepříjemnily využití možnosti prokázat se digitální občankou u volebních komisí při volbách do Poslanecké sněmovny.

    Ladislav Hagara | Komentářů: 2
    dnes 12:33 | Zajímavý software

    Společnost Meta představila OpenZL. Jedná se o open source framework pro kompresi dat s ohledem na jejich formát. Zdrojové kódy jsou k dispozici na GitHubu.

    Ladislav Hagara | Komentářů: 0
    dnes 03:33 | IT novinky

    Google postupně zpřístupňuje českým uživatelům Režim AI (AI Mode), tj. nový režim vyhledávání založený na umělé inteligenci. Režim AI nabízí pokročilé uvažování, multimodalitu a možnost prozkoumat jakékoliv téma do hloubky pomocí dodatečných dotazů a užitečných odkazů na weby.

    Ladislav Hagara | Komentářů: 0
    včera 18:11 | Nová verze

    Programovací jazyk Python byl vydán v nové major verzi 3.14.0. Podrobný přehled novinek v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 2
    včera 16:33 | IT novinky

    Bylo oznámeno, že Qualcomm kupuje Arduino. Současně byla představena nová deska Arduino UNO Q se dvěma čipy: MPU Qualcomm Dragonwing QRB2210, na kterém může běžet Linux, a MCU STM32U585 a vývojové prostředí Arduino App Lab.

    Ladislav Hagara | Komentářů: 2
    včera 15:55 | Nová verze

    Multiplatformní open source voxelový herní engine Luanti byl vydán ve verzi 5.14.0. Podrobný přehled novinek v changelogu. Původně se jedná o Minecraftem inspirovaný Minetest v říjnu loňského roku přejmenovaný na Luanti.

    Ladislav Hagara | Komentářů: 0
    včera 13:22 | Nová verze

    Byla vydána nová stabilní verze 6.10 (YouTube) multiplatformního frameworku a GUI toolkitu Qt. Podrobný přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    6.10. 23:55 | Komunita

    Ubuntu 26.04 LTS bude (𝕏) Resolute Raccoon (rezolutní mýval).

    Ladislav Hagara | Komentářů: 5
    6.10. 21:00 | Nová verze

    Netwide Assembler (NASM) byl vydán v nové major verzi 3.00. Přehled novinek v poznámkách k vydání v aktualizované dokumentaci.

    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (39%)
     (45%)
     (15%)
     (17%)
     (21%)
     (15%)
     (17%)
     (15%)
     (15%)
    Celkem 196 hlasů
     Komentářů: 13, poslední dnes 07:41
    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: 402×

    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.