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 05:22 | Komunita

    Přímý přenos (YouTube) z konference LinuxDays 2025, jež probíhá tento víkend v Praze v prostorách FIT ČVUT. Na programu je spousta zajímavých přednášek.

    Ladislav Hagara | Komentářů: 0
    včera 22:44 | IT novinky

    V únoru loňského roku Úřad pro ochranu osobních údajů pravomocně uložil společnosti Avast Software pokutu 351 mil. Kč za porušení GDPR. Městský soud v Praze tuto pokutu na úterním jednání zrušil. Potvrdil ale, že společnost Avast porušila zákon, když skrze svůj zdarma dostupný antivirový program sledovala, které weby jeho uživatelé navštěvují, a tyto informace předávala dceřiné společnosti Jumpshot. Úřad pro ochranu osobních údajů

    … více »
    Ladislav Hagara | Komentářů: 1
    včera 19:00 | Nová verze

    Google Chrome 141 byl prohlášen za stabilní. Nejnovější stabilní verze 141.0.7390.54 přináší řadu novinek z hlediska uživatelů i vývojářů. Podrobný přehled v poznámkách k vydání. Opraveno bylo 21 bezpečnostních chyb. Za nejvážnější z nich (Heap buffer overflow in WebGPU) bylo vyplaceno 25 000 dolarů. Vylepšeny byly také nástroje pro vývojáře.

    Ladislav Hagara | Komentářů: 0
    včera 17:11 | Upozornění

    eDoklady mají kvůli vysoké zátěži technické potíže. Ministerstvo vnitra doporučuje vzít si sebou klasický občanský průkaz nebo pas.

    Ladislav Hagara | Komentářů: 4
    včera 17:00 | Komunita

    Novým prezidentem Free Software Foundation (FSF) se stal Ian Kelling.

    Ladislav Hagara | Komentářů: 1
    včera 14:33 | Komunita

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za září (YouTube).

    Ladislav Hagara | Komentářů: 0
    včera 12:33 | Upozornění

    Vyšla kniha Počítačové programy a autorské právo. Podle internetových stránek nakladatelství je v knize "Významný prostor věnován otevřenému a svobodnému softwaru, jeho licencím, důsledkům jejich porušení a rizikům „nakažení“ proprietárního kódu režimem open source."

    javokajifeng | Komentářů: 0
    včera 01:11 | Bezpečnostní upozornění

    Red Hat řeší bezpečnostní incident, při kterém došlo k neoprávněnému přístupu do GitLab instance používané svým konzultačním týmem.

    Ladislav Hagara | Komentářů: 0
    2.10. 23:33 | Nová verze

    Immich byl vydán v první stabilní verzi 2.0.0 (YouTube). Jedná se o alternativu k výchozím aplikacím od Googlu a Applu pro správu fotografií a videí umožňující vlastní hosting serveru Immich. K vyzkoušení je demo. Immich je součástí balíčků open source aplikací FUTO. Zdrojové kódy jsou k dispozici na GitHubu pod licencí AGPL-3.0.

    Ladislav Hagara | Komentářů: 2
    2.10. 22:33 | IT novinky

    Český telekomunikační úřad vydal zprávy o vývoji cen a trhu elektronických komunikací se zaměřením na rok 2024. Jaká jsou hlavní zjištění? V roce 2024 bylo v ČR v rámci služeb přístupu k internetu v pevném místě přeneseno v průměru téměř 366 GB dat na jednu aktivní přípojku měsíčně – celkově jich tak uživateli bylo přeneseno přes 18 EB (Exabyte). Nejvyužívanějším způsobem přístupu k internetu v pevném místě zůstal v roce 2024 bezdrátový

    … více »
    Ladislav Hagara | Komentářů: 0
    Jaké řešení používáte k vývoji / práci?
     (38%)
     (46%)
     (14%)
     (16%)
     (18%)
     (14%)
     (18%)
     (15%)
     (14%)
    Celkem 169 hlasů
     Komentářů: 11, poslední včera 07:30
    Rozcestník

    Dotaz: SQL napric tabulkami a sloupci

    2.5.2015 17:27 luksyk
    SQL napric tabulkami a sloupci
    Přečteno: 575×
    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: 46 | 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: 46 | 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: 46 | 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.