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 | Pozvánky

Spolek OpenAlt zve příznivce otevřených technologií a otevřeného přístupu na 151. brněnský sraz, který proběhne v pátek 20. 4. od 18:00 hodin v restauraci Benjamin na Drobného 46.

Ladislav Hagara | Komentářů: 0
dnes 13:33 | Nová verze

Byla vydána verze 18.04.0 KDE Aplikací (KDE Applications). Přehled novinek v kompletním seznamu změn a na stránce s dalšími informacemi.

Ladislav Hagara | Komentářů: 0
dnes 13:11 | Nová verze

Bylo oznámeno vydání nové stabilní verze 1.26 a beta verze 1.27 open source textového editoru Atom (Wikipedie). Přehled novinek i s náhledy v příspěvku na blogu. Podrobnosti v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
dnes 12:55 | Komunita

Dle plánu byla dnes vydána hra Rise of the Tomb Raider (Wikipedie) pro Linux. Koupit ji lze za 49,99 €.

Ladislav Hagara | Komentářů: 0
dnes 09:55 | Bezpečnostní upozornění

Společnost Oracle vydala čtvrtletní bezpečnostní aktualizaci svých softwarových produktů (CPU, Critical Patch Update). Opraveno bylo celkově 254 bezpečnostních chyb. V Oracle Java SE je například opraveno 14 bezpečnostních chyb. Vzdáleně zneužitelných bez autentizace je 12 z nich. V Oracle MySQL je opraveno 33 bezpečnostních chyb. Vzdáleně zneužitelné bez autentizace jsou 2 z nich.

Ladislav Hagara | Komentářů: 2
včera 23:11 | Nová verze

Byla vydána verze 8.0 linuxové distribuce Trisquel GNU/Linux. Nejnovější verze Trisquel nese kódové jméno Flidas a bude podporována do roku 2021. Výchozím prostředím je nově MATE 1.12. Trisquel patří mezi svobodné distribuce doporučované Nadací pro svobodný software (FSF).

Ladislav Hagara | Komentářů: 0
včera 16:00 | Nová verze

Byla vydána nová verze 27.9.0 webového prohlížeče Pale Moon (Wikipedie) vycházejícího z Firefoxu. Přehled novinek v poznámkách k vydání. Jedná se o poslední větší aktualizaci verze 27. Vývojáři se zaměří na novou verzi 28.

Ladislav Hagara | Komentářů: 0
včera 12:00 | Nová verze

Google Chrome 66 byl prohlášen za stabilní (YouTube). Nejnovější stabilní verze 66.0.3359.117 tohoto webového prohlížeče přináší řadu oprav a vylepšení. Vylepšeny byly také nástroje pro vývojáře (YouTube). Opraveno bylo 62 bezpečnostních chyb.

Ladislav Hagara | Komentářů: 0
včera 06:00 | Nová verze

Byla vydána druhá RC verze nové řady 2.10 svobodné aplikace pro úpravu a vytváření rastrové grafiky GIMP. Přehled novinek i s náhledy v oznámení o vydání.

Ladislav Hagara | Komentářů: 0
17.4. 23:39 | Pozvánky

Již tento čtvrtek (19. 4.) se v posluchárně 107 na Fakultě informačních technologií ČVUT v Praze Dejvicích odehraje večer s Turrisem, tentokrát zaměřený na nový modulární router MOX. Mluvit o něm budou Patrick Zandl a Ondřej Filip, ale bude i prostor pro dotazy a diskuzi s vývojáři. Akce začíná v 18:00 a plánovaný konec je v 19:45. Mapka, kde se nachází daná posluchárna, a možnost registrace je k dispozici na webu CZ.NIC.

Miška | Komentářů: 0
Používáte na serverech port knocking?
 (2%)
 (7%)
 (47%)
 (27%)
 (16%)
Celkem 321 hlasů
 Komentářů: 29, poslední 5.4. 12:25
    Rozcestník

    Dotaz: SQL napric tabulkami a sloupci

    2.5.2015 17:27 luksyk
    SQL napric tabulkami a sloupci
    Přečteno: 503×
    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: 41 | 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: 46 | 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-Výuka.cz, Nekuřák.net
    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: 41 | 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: 68
    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: 41 | 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: 68
    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.