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 04:33 | IT novinky

    Společnost Espressif (ESP8266, ESP32, …) získala většinový podíl ve společnosti M5Stack, čímž posiluje ekosystém AIoT.

    Ladislav Hagara | Komentářů: 0
    včera 23:44 | Nová verze

    Byla vydána nová stabilní verze 3.5 svobodného multiplatformního softwaru pro editování a nahrávání zvukových souborů Audacity (Wikipedie). Přehled novinek také na YouTube. Nově lze využívat cloud (audio.com). Ke stažení je oficiální AppImage. Zatím starší verze Audacity lze instalovat také z Flathubu a Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    včera 16:44 | Zajímavý článek

    50 let operačního systému CP/M, článek na webu Computer History Museum věnovaný operačnímu systému CP/M. Gary Kildall z Digital Research jej vytvořil v roce 1974.

    Ladislav Hagara | Komentářů: 0
    včera 16:22 | Pozvánky

    Byl zveřejněn program a spuštěna registrace na letošní konferenci Prague PostgreSQL Developer Day, která se koná 4. a 5. června. Na programu jsou 4 workshopy a 8 přednášek na různá témata o PostgreSQL, od konfigurace a zálohování po využití pro AI a vector search. Stejně jako v předchozích letech se konference koná v prostorách FIT ČVUT v Praze.

    TomasVondra | Komentářů: 0
    včera 03:00 | IT novinky

    Po 48 letech Zilog končí s výrobou 8bitového mikroprocesoru Zilog Z80 (Z84C00 Z80). Mikroprocesor byl uveden na trh v červenci 1976. Poslední objednávky jsou přijímány do 14. června [pdf].

    Ladislav Hagara | Komentářů: 6
    včera 02:00 | IT novinky

    Ještě letos vyjde Kingdom Come: Deliverance II (YouTube), pokračování počítačové hry Kingdom Come: Deliverance (Wikipedie, ProtonDB Gold).

    Ladislav Hagara | Komentářů: 3
    21.4. 19:11 | Komunita

    Thunderbird 128, příští major verze naplánovaná na červenec, přijde s nativní podporou Exchange napsanou v Rustu.

    Ladislav Hagara | Komentářů: 21
    21.4. 04:44 | Komunita

    Byly vyhlášeny výsledky letošní volby vedoucího projektu Debian (DPL, Wikipedie). Novým vedoucím je Andreas Tille.

    Ladislav Hagara | Komentářů: 7
    21.4. 00:11 | Nová verze

    Po osmi měsících vývoje byla vydána nová verze 0.12.0 programovacího jazyka Zig (GitHub, Wikipedie). Přispělo 268 vývojářů. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 2
    20.4. 23:55 | Pozvánky

    Poslední měsíc byl plný zajímavých akcí, o kterých Vám bastlíři z projektu MacGyver mohou povědět, protože se na ně sami vydali. Kde všude byli, ptáte se? Objevili se na Installfestu, Arduino Day, Hackaday Europe a tajném srazu bastlířů z Twitteru. A z každé akce pro vás mají zajímavé poznatky.

    … více »
    bkralik | Komentářů: 1
    KDE Plasma 6
     (71%)
     (10%)
     (2%)
     (17%)
    Celkem 670 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Dotaz: SQL napric tabulkami a sloupci

    2.5.2015 17:27 luksyk
    SQL napric tabulkami a sloupci
    Přečteno: 529×
    dobry den,

    mam nekolik tabulek v MySQL jejichz obsah je zhruba tento:
    | ID | VALUE1 | VALUE2 | VALUE3 |
    | 1  | a1     | a10    | a5     |
    | 2  | a11    | a3     | a40    |
    | 3  | a66    | a13    | a0     |
    
    a ted bych rad vybral vsechny zaznamy, ktere obsahuji pismeno "a" a mel je serazene (idealne natural sort, ale netrvam na tom) a to tak, aby vysledek vypadal nejak takto:
    | ID | VALUE  |
    | 3  | a0     |
    | 1  | a1     |
    | 2  | a3     |
    | 1  | a5     |
    | 1  | a10    |
    | 2  | a11    |
    | 3  | a13    |
    | 2  | a40    |
    | 3  | a66    |
    
    zatim to delam hloupe tak, ze to vyhledavam separe a pak to sortuju v PHP. zajima mne, jestli lze sestavit SQL dotaz, ktery by to sam zvladnul

    dekuji.

    Odpovědi

    2.5.2015 17:55 jekub
    Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
    Ano, rika se tomu join
    2.5.2015 17:57 jekub
    Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
    sory, beru zpet. Neprecetl sem si poradne dotaz.
    2.5.2015 18:00 Kit | skóre: 45 | Brno
    Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
    Použij UNION ALL
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    2.5.2015 23:42 Tomáš
    Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci

    select
      T.ID
      ,case E.VAL
         when 'VALUE1' then T.VALUE1
         when 'VALUE2' then T.VALUE2
         when 'VALUE3' then T.VALUE3
       end as VALUE
    from T
    cross join razdvatri as E
    order by VALUE
    
    tabulka razdvatri vypadá následovně:
    'VAL'
    ----
    VALUE1
    VALUE2
    VALUE3
    

    Stačí si uvědomit, že jeden zdrojový řádek se roznásobí na tři cílové. Jakým trikem si tabulku razdvatri vyrobíte je na vás.

    Sort je jen třešinka na dortu.

    Další varinata je udělat union ze tří selectů {VALUE1,VALUE2,VALUE3}, ale to znamená sjíždět tabulku T 3× což asi nebude úplně optimální. Paradoxně join na třířádkouvou tabulku razrazdvatři, pravděpodobně vyjde z rychlostně lépe.

    xkucf03 avatar 2.5.2015 23:44 xkucf03 | skóre: 49 | blog: xkucf03
    Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
    SELECT * FROM (
        SELECT id, value1 AS value FROM tabulka WHERE value1 LIKE '%a%'
        UNION ALL
        SELECT id, value2 AS value FROM tabulka WHERE value2 LIKE '%a%'
        UNION ALL
        SELECT id, value2 AS value FROM tabulka WHERE value2 LIKE '%a%'
    ) AS t ORDER BY t.value
    Mám rád, když se lidé přou, znamená to, že vědí, co dělají, a že mají směr. Frantovo.cz, SQL-DK, Relational pipes
    3.5.2015 09:03 Filip Jirsák
    Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
    Pokud potřebujete dělat takovéhle dotazy a dávají smysl, pak to především vypadá, že máte špatně navrženou strukturu databáze. Že by ta tabulka měla vypadat takhle nějak:
    | ID | TYPE  | VALUE |
    | 1  | VALUE1| a1    |
    | 1  | VALUE2| a10   |
    | 1  | VALUE3| a5    |
    | 2  | VALUE1| a11   |
    | 2  | VALUE2| a3    |
    | 2  | VALUE3| a40   |
    | 3  | VALUE1| a66   |
    | 3  | VALUE2| a13   |
    | 3  | VALUE3| a0    |
    
    Pak by i ten vámi požadovaný dotaz byl triviální.
    3.5.2015 10:19 Kit | skóre: 45 | Brno
    Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
    EAV má zase nevýhody ve spoustě jiných typů dotazů.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    Josef Kufner avatar 4.5.2015 15:58 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
    Z praktické zkušenosti mohu říct, že nevýhody značně převažují. Než EAV je lepší mít dynamickou strukturu databáze a nechat aplikaci si upravovat vybrané tabulky. Druhá možnost je JSON a serializace z pohledu databáze nepodstatných údajů do jednoho sloupce. Záleží na situaci.
    Hello world ! Segmentation fault (core dumped)
    4.5.2015 18:32 Kit | skóre: 45 | Brno
    Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
    Nebo použít PostgreSQL a hstore.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    4.5.2015 16:34 Filip Jirsák
    Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
    Není jisté, že jde o EAV – je možné, že to vzniklo až zjednodušením pro dotaz v poradně. Vzhledem k tomu, jaký požaduje tazatel výstup, bych spíš tipoval, že o EAV nejde (požadovaný výstup by pak nedával moc smysl).
    Josef Kufner avatar 4.5.2015 15:56 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: SQL napric tabulkami a sloupci
    SQL neumí pracovat s proměnlivým počtem sloupců. Viděl bych to na nešikovně navrženou databázi, ale pokud jinak dává smysl, tak řešením je UNION selectů nad jednotlivými sloupci (jak už zde bylo řečeno).
    Hello world ! Segmentation fault (core dumped)

    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.