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

Byl vydán Docker 1.13. Přehled novinek na YouTube a v poznámkách k vydání na GitHubu. Docker umožňuje běh aplikací v softwarových kontejnerech (Wikipedia).

Ladislav Hagara | Komentářů: 0
dnes 15:51 | Komunita

Mozilla.cz informuje, že nástroje pro webové vývojáře se možná oddělí od Firefoxu a stanou doplňkem. Nástroje pro webové vývojáře prošly velkým přepisem a tým, který se stará o jejich vývoj, by uvítal možnost jejich častějších aktualizacích nezávisle na vydávání nových verzí Firefoxu.

Ladislav Hagara | Komentářů: 1
dnes 07:00 | Humor

Čtenářům AbcLinuxu vše nejlepší k dnešnímu Dni zvýšení povědomí o tučňácích (Penguin Awareness Day).

Ladislav Hagara | Komentářů: 0
dnes 06:00 | Komunita

Bylo spuštěno hlasování o přednáškách a workshopech pro letošní InstallFest, jenž proběhne o víkendu 4. a 5. března v Praze. Současně byla oznámena změna místa. InstallFest se letos vrací zpět na Karlovo náměstí do budovy E.

Ladislav Hagara | Komentářů: 0
dnes 02:48 | Komunita

Greg Kroah-Hartman potvrdil, že Linux 4.9 je jádrem s prodlouženou upstream podporou (LTS, Long Term Support). Podpora je plánována do ledna 2019. Aktuální jádra s prodlouženou podporou jsou tedy 3.2, 3.4, 3.10, 3.12, 3.16, 3.18, 4.1, 4.4 a 4.9.

Ladislav Hagara | Komentářů: 0
dnes 00:11 | Zajímavý článek

Výrobce síťových prvků, společnost Netgear, spustila nový program, který slibuje vývojářům, expertům, ale i běžným uživatelům vyplacení finanční odměny za nalezení bezpečnostních chyby v jejich produktech. Za nalezení zranitelnosti v hardware, API nebo mobilní aplikaci nabízí odměnu od 150 do 15 tisíc dolarů (dle závažnosti).

Michal Makovec | Komentářů: 0
dnes 00:08 | Pozvánky

V sobotu 18. 2. se v Praze v prostorách VŠE uskuteční od 9:30 již 4. ročník největší české konference o open source redakčním systému WordPress (WP) - WordCamp Praha 2017.

… více »
smíťa | Komentářů: 0
včera 23:58 | Komunita

Kryptoměnová komunita zahájila nový rok spuštěním projektu Blockchain.cz, jehož cílem je kolektivně nalézt ideální překlad pro čím dál frekventovanější slovo „blockchain“. Přispět návrhem může kdokoli. Sběr bude trvat až do konce září 2017. Následně bude probíhat dvoutýdenní veřejné hlasování, které bude zakončeno výběrem toho nejlepšího návrhu.

xHire | Komentářů: 8
včera 15:55 | Bezpečnostní upozornění

Společnost Oracle vydala čtvrtletní bezpečnostní aktualizaci svých softwarových produktů (CPU, Critical Patch Update). Opraveno je celkově 270 bezpečnostních chyb. V Oracle Java SE je například opraveno 17 bezpečnostních chyb. Vzdáleně zneužitelných bez autentizace je 16 z nich. V Oracle MySQL je opraveno 27 bezpečnostních chyb. Vzdáleně zneužitelných bez autentizace je 5 z nich.

Ladislav Hagara | Komentářů: 0
včera 02:48 | Nová verze

Po půl roce od vydání verze 9.0 (zprávička) byla vydána verze 10.0 zvukového serveru PulseAudio. Přehled novinek v poznámkách k vydání.

Ladislav Hagara | Komentářů: 31
Jak se stavíte k trendu ztenčování přenosných zařízení (smartphony, notebooky)?
 (10%)
 (2%)
 (74%)
 (3%)
 (10%)
Celkem 338 hlasů
 Komentářů: 24, poslední 17.1. 10:14
    Rozcestník
    Reklama

    Dotaz: Jak na výpis položek ze stromu kategorie v PHP

    5.4.2014 13:05 JaN
    Jak na výpis položek ze stromu kategorie v PHP
    Přečteno: 509×
    Zdravím. Mám v mysql nějaké kategorie a taky položky. Nevím ale jak vypsat položky ze všech kategorií které patří pod sebe. Pokud bude třeba aktivní kategorie "Sestavy", tak vypsat všechny položky taky z kategorie "Nove" a "AMD" a "Intel". Pokud bude aktivní "Sestavy > Nové", tak vypsat už jen kategorie "AMD" a "Intel". Atd.. Neporadí někdo? Děkuji
    kategorie mám
    
    cat_id    cat_name   cat_parent
    1         Sestavy    0
    2         Servery    0
    3         Nove       1
    4         Nove       2
    5         Použité    1
    6         Použité    2
    7         AMD        3
    8         Intel      3
    
    
    a položky mám
    
    item_id    item_name     cat_id
    1          Položka A     4
    2          Položka B     5
    3          Položka C     5
    4          Položka D     4
    5          Položka E     6
    6          Položka F     6
    7          Položka G     7
    8          Položka H     8

    Odpovědi

    Josef Kufner avatar 5.4.2014 14:42 Josef Kufner | skóre: 66
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    Přidej si do tabulky dva sloupečky typu int: tree_left a tree_right. Udělej nad nima index, aby to bylo rychlé a přečti si o nested sets.

    Pak ti stačí pro výběr podstromu prostý výběr všeho s tree_left mezi tree_left a tree_right kořene podstromu.
    Hello world ! Segmentation fault (core dumped)
    6.4.2014 12:28 JaN
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    Ahoj.
    Udělej nad nima index, aby to bylo rychlé
    Udělej nad nima index ? Můžeš ještě trochu přiblížit ?
    Pak ti stačí pro výběr podstromu prostý výběr všeho s tree_left mezi tree_left a tree_right kořene podstromu.
    Tato věta mi nedává moc k pochopení, jelikož nejsem znalý dané problematiky. Můžeš prosím v podobě pro začátečníka?

    Děkuji
    Jendа avatar 6.4.2014 16:38 Jendа | skóre: 73 | blog: Výlevníček | JO70FB
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    Udělej nad nima index ? Můžeš ještě trochu přiblížit ?
    CREATE INDEX brm ON tabulka (sloupeček);
    Tato věta mi nedává moc k pochopení, jelikož nejsem znalý dané problematiky. Můžeš prosím v podobě pro začátečníka?
    Viděl jsi ten obrázek na Wikipedii? Myslím, že je z něj jasné, jak se takové věci vyptává na podmnožiny.
    „To jsem nedávno zjistil, že naše televize jde ovládat po síti. Docela mě to překvapilo.“ „Jo? A kdo vám ji ovládal?“
    7.4.2014 13:33 JaN
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    Viděl jsi ten obrázek na Wikipedii?
    Ano, víděl, a dokážeš si představit přidat tam další kategorii? Počítání na dva dny :-(
    7.4.2014 14:55 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP

    I při tisících kategorií a na CPU z telefonu je to otázka sekundy.
    Pokud chceš rychle a dynamicky vytahovat kategorie, tak je to to správné.

    Jinak si můžeš zhodnotit sám - a pokud si líný, tak zkus hledat toto.
    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    7.4.2014 16:17 JaN
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    Nepochopil jsi co jsem napsal ;-) Nemyslel jsem rychlost načítání/zpracování ale poukazoval jsem na to, že pokud mít v mysql nějaký strom a budu tam chtít přidat nějaké kategorie tak to znamená všechno přepočítat, což musím patrně udělat ručně. Tak že pokud tam budu mít cca 500 kategorií tak to udělám tak za dva dny, pokud se teda spíš neobjesím :-D Nebo jsem to nepochopil? Dělá se to jinak?
    7.4.2014 16:31 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP

    Já jo, ty ne - znovu: I při tisících kategorií a na CPU z telefonu je to otázka sekundy.

    Kdyby jsi si aspoň přečetl odkazovaný článek do konce, nemohl by jsi napsat, co jsi napsal. Nebo zkusil zapřemýšlet co máš hledat dle nápovědy v druhém odkazu.

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    7.4.2014 18:45 JaN
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    Četl jsem to, ale anglicky neumím, tak že jsem možná něco přehlédl.

    Stejně to je celý nějaké divné... Vytvořil jsem si tabulku "cat" V ní tyto 4 sloupce s daty
    Node	Left	Right	Depth
    Clothing	1	22	0
    Men's	        2	9	1
    Women's	        10	21	1
    Suits	        3	8	2
    Slacks	        4	5	3
    Jackets	        6	7	3
    Dresses	        11	16	2
    Skirts	        17	18	2
    Blouses	        19	20	2
    Evening Gowns	12	13	3
    Sun Dresses	14	15	3
    
    a při použití tohoto dotazu se mi nevypíše nic. Ani se nedivím, když tam žádné sloupce s názvy Child Tree Parent ani Given nemám :-(
    SELECT Child.Node, Child.LEFT, Child.RIGHT
    FROM Tree AS Child, Tree AS Parent
    WHERE
    	Child.Depth = Parent.Depth + 1
    	AND Child.LEFT > Parent.LEFT
    	AND Child.RIGHT < Parent.RIGHT
    	AND Parent.LEFT = 1  -- Given Parent Node Left Index
    7.4.2014 18:59 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP

    ¡Odkazoval jsem český text! Takže na to fakt kašleš…

    Dotaz je pro tabulku strom (Tree) a ty tam máš čičiny (cat), pokud to z toho nevyčteš, chce se to podívat na nějakou základní syntaxi SQL.

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    7.4.2014 19:13 JaN
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    Snažím se ani nevíš jak moc to potřebuji vyřešit :-( A co ty ostatní názvy Child Parent Given ? Ty mám vzít kde? Posílal jsi český odkaz to vím, ale na něco jiného, řeším ale tohle : https://en.wikipedia.org/wiki/Nested_set_model
    Jendа avatar 7.4.2014 20:01 Jendа | skóre: 73 | blog: Výlevníček | JO70FB
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    Najdi si nějakou příručku se základy SQL. Child a Parent jsou přejmenované tabulky (slovíčkem AS), slovo Given se vyskytuje pouze v komentáři.
    „To jsem nedávno zjistil, že naše televize jde ovládat po síti. Docela mě to překvapilo.“ „Jo? A kdo vám ji ovládal?“
    7.4.2014 20:08 JaN
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    Určitě si něco najdu... Jinak už to běží, teda jestli se to tak dá nazvat, vypíšou se pouze dva názvy kategorie, žádný strom se ale nevypsal :-(
    7.4.2014 21:44 Šangala | skóre: 56 | blog: Dutá Vrba - Wally
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP

    Snaha není koksovatelná.

    Když máš pocit, že jsem ti poslal něco jiného, tak to je pak těžké...

    Na závěr, myslím, že nemáš dostatek znalostí a přijde mi, že se po nic ani nepídíš, takže bych ti doporučil se zabývát mým druhým hintem a jí touto cestou.

    To, že trpíš stihomamem, ještě neznamená, že po tobě nejdou. ⰞⰏⰉⰓⰀⰜⰉ ⰗⰞⰅⰜⰘ ⰈⰅⰏⰉ ⰒⰑⰎⰉⰁⰕⰅ ⰏⰉ ⰒⰓⰄⰅⰎ ·:⁖⁘⁙†
    Jendа avatar 7.4.2014 19:56 Jendа | skóre: 73 | blog: Výlevníček | JO70FB
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    > update `counter_ip` set id=id-100000
    ...
    Příkaz proběhl v pořádku, bylo změněno 8 190 záznamů. (0.126 s)
    Pentium III
    „To jsem nedávno zjistil, že naše televize jde ovládat po síti. Docela mě to překvapilo.“ „Jo? A kdo vám ji ovládal?“
    7.4.2014 20:07 JaN
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    ? Ty to taky používáš ten system?
    Jendа avatar 7.4.2014 20:41 Jendа | skóre: 73 | blog: Výlevníček | JO70FB
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    Ne, jen jsem ukazoval, že i na slabém počítači trvá update několika tisíc čísel zlomek sekundy - takže i když budeš mít tisíc kategorií, přidání další bude trvat chvilku.
    „To jsem nedávno zjistil, že naše televize jde ovládat po síti. Docela mě to překvapilo.“ „Jo? A kdo vám ji ovládal?“
    7.4.2014 21:06 JaN
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    Aha, díky... a poradíš tedy prosím jak vypsat celý ten strom? Díky
    Jendа avatar 7.4.2014 21:26 Jendа | skóre: 73 | blog: Výlevníček | JO70FB
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    Napiš dotaz, ke kterému jsi zatím dospěl…
    „To jsem nedávno zjistil, že naše televize jde ovládat po síti. Docela mě to překvapilo.“ „Jo? A kdo vám ji ovládal?“
    7.4.2014 21:46 JaN
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    $stmt = $pdo->prepare('SELECT Child.Node, Child.LEFT, Child.RIGHT
                           FROM cat AS Child, cat AS Parent
                           WHERE
                           Child.Depth = Parent.Depth + 1
                           AND Child.LEFT > Parent.LEFT
                           AND Child.RIGHT < Parent.RIGHT
                           AND Parent.LEFT = 1  -- Given Parent Node Left Index');
    $stmt->execute();
    $rows = $stmt->fetchAll();
    foreach ($rows as $row) {
         echo $row['Node'];
    }
    Jendа avatar 7.4.2014 22:01 Jendа | skóre: 73 | blog: Výlevníček | JO70FB
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    Dělá to přesně to, co by mělo - vypíše děti kategorie č. 1. Jestli to chceš vypsat celé, tak
    SELECT Child.Node, Child.LEFT, Child.RIGHT, Child.depth
                           FROM cat AS Child, cat AS Parent
                           WHERE
                           Child.Depth = Parent.Depth + 1
                           AND Child.LEFT > Parent.LEFT
                           AND Child.RIGHT < Parent.RIGHT
    			order by Child.LEFT;
    „To jsem nedávno zjistil, že naše televize jde ovládat po síti. Docela mě to překvapilo.“ „Jo? A kdo vám ji ovládal?“
    Josef Kufner avatar 7.4.2014 22:15 Josef Kufner | skóre: 66
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    Btw, na tento způsob uložení stromu do SQL databáze už existuje kopec knihoven, které ty left a right umí spočítat a umí efektivně udělat insert či delete ze stromu. Konkrétní nedoporučím, neboť jsem to kdysi dělal podle toho odkazovaného návodu, ale na pár jsem omylem narazil, když jsem ten návod teď hledal.
    Hello world ! Segmentation fault (core dumped)
    7.4.2014 21:55 Kit | skóre: 37 | Brno
    Rozbalit Rozbalit vše Re: Jak na výpis položek ze stromu kategorie v PHP
    Něco podobného jsem kdysi řešil a dospěl jsem k funkčnímu řešení. Ve vstupních datech je klasická "špatná" struktura pouze s odkazem na rodiče, výstupem je například strom diskuzního fóra v HTML.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.

    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.