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í
×
eParkomat, startup z ČR, postoupil mezi finalisty evropského akcelerátoru ChallengeUp!
Robot na pivo mu otevřel dveře k opravdovému byznysu
Internet věcí: Propojený svět? Už se to blíží...
dnes 21:21 | Nová verze Ladislav Hagara | Komentářů: 0
dnes 11:44 | Zajímavý projekt

Na Indiegogo byla spuštěna kampaň na podporu herní mini konzole a multimediálního centra RetroEngine Sigma od Doyodo. Předobjednat ji lze již od 49 dolarů. Požadovaná částka 20 000 dolarů byla překonána již 6 krát. Majitelé mini konzole si budou moci zahrát hry pro Atari VCS 2600, Sega Genesis nebo NES. Předinstalováno bude multimediální centrum Kodi.

Ladislav Hagara | Komentářů: 0
dnes 00:10 | Nová verze

Byla vydána verze 4.7 redakčního systému WordPress. Kódové označením Vaughan bylo vybráno na počest americké jazzové zpěvačky Sarah "Sassy" Vaughan. Z novinek lze zmínit například novou výchozí šablonu Twenty Seventeen, náhledy pdf souborů nebo WordPress REST API.

Ladislav Hagara | Komentářů: 0
včera 12:00 | Zajímavý projekt

Projekt Termbox umožňuje vyzkoušet si linuxové distribuce Ubuntu, Debian, Fedora, CentOS a Arch Linux ve webovém prohlížeči. Řešení je postaveno na projektu HyperContainer. Podrobnosti v často kladených dotazech (FAQ). Zdrojové kódy jsou k dispozici na GitHubu [reddit].

Ladislav Hagara | Komentářů: 24
včera 11:00 | Bezpečnostní upozornění

Byly zveřejněny informace o bezpečnostní chybě CVE-2016-8655 v Linuxu zneužitelné k lokální eskalaci práv. Chyba se dostala do linuxového jádra v srpnu 2011. V upstreamu byla opravena minulý týden [Hacker News].

Ladislav Hagara | Komentářů: 2
5.12. 22:00 | Komunita

Přibližně před měsícem bylo oznámeno, že linuxová distribuce SUSE Linux Enterprise Server (SLES) běží nově také Raspberry Pi 3 (dokumentace). Obraz verze 12 SP2 pro Raspberry Pi 3 je ke stažení zdarma. Pro registrované jsou po dobu jednoho roku zdarma také aktualizace. Dnes bylo oznámeno, že pro Raspberry Pi 3 je k dispozici také nové openSUSE Leap 42.2 (zprávička). K dispozici je hned několik obrazů.

Ladislav Hagara | Komentářů: 6
5.12. 06:00 | Zajímavý software

OMG! Ubuntu! představuje emulátor terminálu Hyper (GitHub) postavený na webových technologiích (HTML, CSS a JavaScript). V diskusi k článku je zmíněn podobný emulátor terminálu Black Screen. Hyper i Black Screen používají framework Electron, stejně jako editor Atom nebo vývojové prostředí Visual Studio Code.

Ladislav Hagara | Komentářů: 50
5.12. 06:00 | Zajímavý článek

I letos vychází řada ajťáckých adventních kalendářů. QEMU Advent Calendar 2016 přináší každý den nový obraz disku pro QEMU. Programátoři se mohou potrápit při řešení úloh z kalendáře Advent of Code 2016. Kalendáře Perl Advent Calendar 2016 a Perl 6 Advent Calendar přinášejí každý den zajímavé informace o programovacím jazyce Perl. Stranou nezůstává ani programovací jazyk Go.

Ladislav Hagara | Komentářů: 10
3.12. 16:24 | Nová verze

Byla vydána Mageia 5.1. Jedná se o první opravné vydání verze 5, jež vyšla v červnu loňského roku (zprávička). Uživatelům verze 5 nepřináší opravné vydání nic nového, samozřejmě pokud pravidelně aktualizují. Vydání obsahuje všechny aktualizace za posledního téměř půldruhého roku. Mageia 5.1 obsahuje LibreOffice 4.4.7, Linux 4.4.32, KDE4 4.14.5 nebo GNOME 3.14.3.

Ladislav Hagara | Komentářů: 17
3.12. 13:42 | Pozvánky

V Praze probíhá konference Internet a Technologie 16.2, volné pokračování jarní konference sdružení CZ.NIC. Konferenci lze sledovat online na YouTube. K dispozici je také archiv předchozích konferencí.

Ladislav Hagara | Komentářů: 0
Kolik máte dat ve svém domovském adresáři na svém primárním osobním počítači?
 (32%)
 (24%)
 (29%)
 (8%)
 (5%)
 (3%)
Celkem 785 hlasů
 Komentářů: 50, poslední 29.11. 15:50
Rozcestník
Reklama

Dotaz: Mysql - dotaz

28.1. 10:29 alio
Mysql - dotaz
Přečteno: 1219×
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. 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. 10:40 NN
Rozbalit Rozbalit vše Re: Mysql - dotaz
Jak vypada tabulka, kdyz ma recept vice kategorii?
28.1. 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. 12:17 Kit | skóre: 36 | 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. 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. 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. 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.