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í
×
včera 13:00 | Komunita

Do 30. října se lze přihlásit do dalšího kola programu Outreachy (Wikipedie), jehož cílem je přitáhnout do světa svobodného a otevřeného softwaru lidi ze skupin, jež jsou ve světě svobodného a otevřeného softwaru málo zastoupeny. Za 3 měsíce práce, od 4. prosince 2018 do 4. března 2019, v participujících organizacích lze vydělat 5 500 USD.

Ladislav Hagara | Komentářů: 50
21.9. 22:22 | Komunita

Společnost Purism představila kryptografický token Librem Key. Koupit jej lze za 59 dolarů. Token byl vyvinut ve spolupráci se společností Nitrokey a poskytuje jak OpenPGP čipovou kartu, tak zabezpečení bootování notebooků Librem a také dalších notebooků s open source firmwarem Heads.

Ladislav Hagara | Komentářů: 8
21.9. 20:33 | Nová verze

Společnost NVIDIA oficiálně vydala verzi 10.0 toolkitu CUDA (Wikipedie) umožňujícího vývoj aplikací běžících na jejich grafických kartách. Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 0
21.9. 20:00 | Upozornění

Příspěvek Jak přežít plánovanou údržbu DNS na blogu zaměstnanců CZ.NIC upozorňuje na historicky poprvé podepsání DNS root zóny novým klíčem dne 11. října 2018 v 18:00. Software, který nebude po tomto okamžiku obsahovat nový DNSSEC root klíč, nebude schopen resolvovat žádná data. Druhým důležitým datem je 1. února 2019, kdy významní výrobci DNS softwaru, také historicky poprvé, přestanou podporovat servery, které porušují DNS standard

… více »
Ladislav Hagara | Komentářů: 8
21.9. 15:55 | Pozvánky

Spolek OpenAlt zve příznivce otevřených řešení a přístupu na 156. brněnský sraz, který proběhne v pátek 21. září od 18:00 v restauraci Na Purkyňce na adrese Purkyňova 80.

Ladislav Hagara | Komentářů: 0
21.9. 13:22 | Nová verze

Alan Griffiths z Canonicalu oznámil vydání verze 1.0.0 display serveru Mir (GitHub, Wikipedie). Mir byl představen v březnu 2013 jako náhrada X serveru a alternativa k Waylandu. Dnes Mir běží nad Waylandem a cílen je na internet věcí (IoT).

Ladislav Hagara | Komentářů: 0
20.9. 22:00 | Nasazení Linuxu
Stabilní aktualizace Chrome OS 69 (resp. Chromium OS), konkrétně 69.0.3497.95, přináší mj. podporu linuxových aplikací. Implementována je pomocí virtualizace, a proto je tato funkce také omezena na zařízení s dostatkem paměti a podporou hardwarové akcelerace, tudíž nejsou podporovány chromebooky s 32bitovými architekturami ARM, či Intel Bay Trail (tzn. bez Intel VT-x).
Fluttershy, yay! | Komentářů: 5
20.9. 21:32 | Zajímavý projekt

Došlo k uvolnění linuxové distribuce CLIP OS, vyvíjené francouzským úřadem pro kybernetickou bezpečnost ANSSI, jako open source. Vznikla za účelem nasazení v úřadech, kde je potřeba omezit přístup k důvěrným datům. Je založená na Gentoo.

Fluttershy, yay! | Komentářů: 1
20.9. 16:00 | Komerce

Zjistěte více o bezpečné a flexibilní architektuře v cloudu! IBM Cloud poskytuje bezpečné úložiště pro Vaše obchodní data s možností škálovatelnosti a flexibilitou ukládání dat. Zároveň nabízí prostředky pro jejich analýzu, vizualizaci, reporting a podporu rozhodování.

… více »
Fluttershy, yay! | Komentářů: 12
20.9. 12:22 | Nová verze

V dubnu letošního roku Mozilla představila webový prohlížeč pro rozšířenou a virtuální realitu Firefox Reality (GitHub). V úterý oznámila vydání verze 1.0. Ukázka na YouTube. Firefox Reality je k dispozici pro Viveport, Oculus a Daydream.

Ladislav Hagara | Komentářů: 2
Na optické médium (CD, DVD, BD aj.) jsem naposledy vypaloval(a) data před méně než
 (13%)
 (15%)
 (21%)
 (23%)
 (25%)
 (4%)
 (1%)
Celkem 393 hlasů
 Komentářů: 33, poslední 16.9. 11:55
Rozcestník

Dotaz: Mysql - dotaz

28.1.2016 10:29 alio
Mysql - dotaz
Přečteno: 1331×
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: 42 | 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.