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 00:22 | Nová verze

    Byla vydána nová stabilní verze 25.05 linuxové distribuce NixOS (Wikipedie). Její kódové označení je Warbler. Podrobný přehled novinek v poznámkách k vydání. O balíčky se v NixOS stará správce balíčků Nix.

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

    Multiplatformní open source spouštěč her Heroic Games Launcher byl vydán v nové stabilní verzi 2.17.0 Franky (Mastodon, 𝕏). Přehled novinek na GitHubu. Instalovat lze také z Flathubu.

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

    Organizace Apache Software Foundation (ASF) vydala verzi 26 integrovaného vývojového prostředí a vývojové platformy napsané v Javě NetBeans (Wikipedie). Přehled novinek na GitHubu. Instalovat lze také ze Snapcraftu a Flathubu.

    Ladislav Hagara | Komentářů: 0
    včera 14:55 | IT novinky

    Klávesnice IBM Enhanced Keyboard, známá také jako Model M, byla poprvé představena v roce 1985, tzn. před 40 lety, s počítači IBM 7531/7532 Industrial Computer a 3161/3163 ASCII Display Station. Výročí připomíná článek na zevrubném sběratelském webu Admiral Shark's Keyboards. Rozložení kláves IBM Enhanced Keyboard se stalo průmyslovým standardem.

    Fluttershy, yay! | Komentářů: 4
    včera 12:00 | Nová verze

    Vyšlo Pharo 13 s vylepšenou podporou HiDPI či objektovým Transcriptem. Pharo je programovací jazyk a vývojové prostředí s řadou pokročilých vlastností.

    Pavel Křivánek | Komentářů: 1
    včera 04:00 | IT novinky

    Java má dnes 30. narozeniny. Veřejnosti byla představena 23. května 1995.

    Ladislav Hagara | Komentářů: 6
    22.5. 21:55 | IT novinky

    1. července Mozilla vypne službu Fakespot pro detekci podvodných recenzí v internetových obchodech. Mozilla koupila Fakespot v květnu 2023.

    Ladislav Hagara | Komentářů: 1
    22.5. 21:33 | IT novinky

    8. července Mozilla vypne službu Pocket (Wikipedie) pro ukládání článků z webu na později. Do 8. října si uživatelé mohou vyexportovat data. Mozilla koupila Pocket v únoru 2017. Několik měsíců byl Pocket integrovanou součástí Firefoxu.

    Ladislav Hagara | Komentářů: 5
    22.5. 13:22 | Upozornění

    Turris OS má aktuálně problém s aktualizací související s ukončením podpory protokolu OCSP u certifikační autority Let's Encrypt.

    Ladislav Hagara | Komentářů: 4
    22.5. 04:00 | Zajímavý článek

    Nevidomý uživatel Linuxu v blogu upozornil na tristní stav přístupnosti na linuxovém desktopu (část první, druhá, závěr), přičemž stížnosti jsou podobné jako v roce 2022. Vyvolal bouřlivou odezvu. Následně např. Georges Stavracas shrnul situaci v GNOME. Debata o jiném aspektu přístupnosti, emulaci vstupu pod Waylandem, také proběhla na Redditu.

    Fluttershy, yay! | Komentářů: 8
    Jaký je váš oblíbený skriptovací jazyk?
     (57%)
     (28%)
     (7%)
     (3%)
     (0%)
     (0%)
     (6%)
    Celkem 90 hlasů
     Komentářů: 6, poslední 22.5. 14:43
    Rozcestník

    Dotaz: Mysql - dotaz

    28.1.2016 10:29 alio
    Mysql - dotaz
    Přečteno: 1380×
    Ahoj,

    řeším jeden složitější SQL dotaz a nevím, jak ho správně sestavit. Můžu poprosit o pomoc?

    Jde o to, že mám tabulky:

    recepty > id, nazev, popis recepty_kategorie > id_receptu, id_kategorie (1 recept = N kategorií) kategorie > id, nazev

    Nacházím se v detailu receptu. A potřebuju vypsat 3 podobné recepty, ze stejných kategorií, jako je vybraný recept.

    Snad jsem to napsal srozumitelně.

    Díky!


    Řešení dotazu:


    Odpovědi

    28.1.2016 10:31 alio
    Rozbalit Rozbalit vše Re: Mysql - dotaz
    Omlouvám se za formátování, napravuji:

    Jde o to, že mám tabulky:

    recepty > id, nazev, popis
    recepty_kategorie > id_receptu, id_kategorie (1 recept = N kategorií)
    kategorie > id, nazev
    Nacházím se v detailu receptu. A potřebuju vypsat 3 podobné recepty, ze stejných kategorií, jako je vybraný recept.

    Snad jsem to napsal srozumitelně.

    Díky!

    28.1.2016 10:40 NN
    Rozbalit Rozbalit vše Re: Mysql - dotaz
    Jak vypada tabulka, kdyz ma recept vice kategorii?
    28.1.2016 12:04 alio
    Rozbalit Rozbalit vše Re: Mysql - dotaz
    recept_id = 1, kategorie_id = 2
    recept_id = 2, kategorie_id = 7
    recept_id = 1, kategorie_id = 12
    recept_id = 3, kategorie_id = 8
    recept_id = 1, kategorie_id = 3
    např.... díky
    28.1.2016 12:17 Kit | skóre: 45 | Brno
    Rozbalit Rozbalit vše Re: Mysql - dotaz
    Nejprve si zkus základní vazbu M:N mezi tabulkami. Pak už jen stačí přidat klauzuli WHERE a případně LIMIT.
    SELECT recepty.id, recepty.nazev, kategorie.id, kategorie.nazev
        FROM recepty
        JOIN recepty_kategorie AS rk ON recepty.id=rk.id_receptu
        JOIN kategorie ON rk.id_kategorie=kategorie.id
    
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    28.1.2016 12:34 alio
    Rozbalit Rozbalit vše Re: Mysql - dotaz
    Děkuji za pomoc.

    Ještě jedna drobnost - ten SQL se volá v detailu receptu a vlastně nabízí podobné recepty tomu, který si uživatel prohlíží.

    Tzn. tomu SQL bych potřeboval říct ještě (a to nedokážu doplnit tak, aby to fungovalo), jaké je aktuální ID receptu (recepty.id=1), aby dotaz nalezl podobné recepty podle stejných kategorií.

    Děkuji všem
    28.1.2016 12:42 ttt
    Rozbalit Rozbalit vše Re: Mysql - dotaz
    WHERE a LIMIT na to nestačí bez toho, aby tam bylo něco natvrdo. Recept 1 spadá do kategorií (a,b,c,...), cíl je najít jiný recept, který spadá do těch samých kategorií. Bude to myslím něco jako
    SELECT rk_other.id_receptu
    FROM recepty
        JOIN recepty_kategorie AS rk ON recepty.id=rk.id_receptu
        JOIN recepty_kategorie AS rk_other USING(id_kategorie)
    WHERE recepty.id = 1
    GROUP BY rk_other.id_receptu
    ORDER BY COUNT(DISTINCT id_kategorie) DESC
    LIMIT 10
    
    28.1.2016 13:07 alio
    Rozbalit Rozbalit vše Re: Mysql - dotaz
    To je přesně ono - díky moc! :)

    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.