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 03:11 | Komunita

    Do 20. února lze hlasovat pro wallpapery pro Ubuntu 26.04 s kódovým názvem Resolute Raccoon.

    Ladislav Hagara | Komentářů: 2
    dnes 02:22 | Nová verze

    Byla vydána lednová aktualizace aneb nová verze 1.109 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.109 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 1
    včera 19:33 | Zajímavý projekt

    Na Kickstarteru běží kampaň na podporu modulárního otevřeného handheldu Mecha Comet s Linuxem.

    Ladislav Hagara | Komentářů: 3
    včera 14:00 | Humor

    V nedávno zveřejněné kolekci dokumentů souvisejících s kontroverzním finančníkem a kuplířem Jeffrey Epsteinem se překvapivě objevil i referenční manuál unixového shellu Bash, jedná se o verzi manuálu z roku 2005. Aktuální vydání si lze stáhnout ze stránek GNU.

    NUKE GAZA! 🎆 | Komentářů: 14
    včera 13:55 | Nová verze

    The Document Foundation oznámila vydání nové verze 26.2 svobodného kancelářského balíku LibreOffice. Podrobný přehled nových vlastností i s náhledy v poznámkách k vydání (cs). Vypíchnout lze podporu formátu Markdown.

    Ladislav Hagara | Komentářů: 0
    včera 12:22 | Pozvánky

    Co se děje ve zprávách, ví asi každý - válka sem, clo tam, demonstrace na jednu i druhou stranu a bastlíř už má pocit, že se snad ani nic jiného neděje. To by však byl velký omyl a Virtuální Bastlírna je zde jako každý měsíc, aby vytáhla na světlo světa události ze světa vědy a techniky. Připojte se tedy nezávaznému povídání Strahovského MacGyvera! Co se tam bude probírat? PCBWay začalo dělat průhledné plošňáky, MARS končí s výrobou skříněk, FEL

    … více »
    bkralik | Komentářů: 0
    včera 12:11 | IT novinky

    Guvernérka státu New York Kathy Hochul (Demokraté) plánuje novou legislativu, která by měla omezit výrobu 3D tištěných zbraní. Tento návrh zákona zavádí povinnost pro všechny 3D tiskárny prodávané ve státě New York obsahovat 'software' bránící ve výrobě zbraní. Návrh zákona rovněž zakazuje lidem sdílet 'digitální plány zbraní' (blueprinty) bez povolení. Existují důvodné obavy, že se tento nešťastný nápad může šířit do dalších zemí a ovlivnit celý 3D tisk jako takový. Ostatně, s podobnou regulací nedávno přišel i stát Washington.

    NUKE GAZA! 🎆 | Komentářů: 23
    včera 05:11 | Komunita

    Na čem pracují vývojáři webového prohlížeče Ladybird (GitHub)? Byl publikován přehled vývoje za prosinec 2025 a leden 2026 (YouTube). Zajímavé, že i v roce 2026 celou řadu problémů vyřeší falšování řetězce User-Agent.

    Ladislav Hagara | Komentářů: 2
    3.2. 20:11 | Komunita

    Bylo rozhodnuto, že Linux From Scratch (LFS) končí s podporou System V init. Nové verze knih s návody na instalaci vlastního linuxového systému ze zdrojových kódů už budou pouze se systemd.

    Ladislav Hagara | Komentářů: 8
    3.2. 17:00 | Nová verze

    Byla vydána nová verze 2026.1.0 "Like a Version" svobodného softwaru ScummVM (Wikipedie) umožňujícího bezproblémový běh mnoha klasických adventur na zařízeních, pro které nebyly nikdy určeny. Přehled novinek v poznámkách k vydání a na GitHubu. Změněno bylo číslování verzí. Předchozí verze byla 2.9.1.

    Ladislav Hagara | Komentářů: 2
    Které desktopové prostředí na Linuxu používáte?
     (18%)
     (6%)
     (0%)
     (10%)
     (25%)
     (3%)
     (5%)
     (2%)
     (12%)
     (30%)
    Celkem 759 hlasů
     Komentářů: 25, poslední 3.2. 19:50
    Rozcestník

    Dotaz: SQL řešení hierarchické strukutury

    16.1.2021 20:52 Karlos
    SQL řešení hierarchické strukutury
    Přečteno: 452×
    Příloha:
    Dobrý den, chtěl poprosit o pomoc při vytvoření SQL skriptu.

    Mám tento datový model, který charakterizuje e-shop a jeho kategorie pro jednotlivé zboží:

    item_category: každá kategorie/subkategorie zboží (list). Pomocí selreferenční vazby parent je definován les stromů kategorií. Kořenové kategorie těchto stromů se nazývají kategorie hlavní.

    item_category_transitive_closure - jde o redundantní datovou strukturu obsahující transitivní uzávěr relace nadkategorie-podkategorie, kterou reprezentuje selferefrenční vazba parent nad tabulkou item_category - jedná se o každou reprezentaci vazby mezi dvěma kategoriemi se smyslu: kategorie (#super_cat_id)-s, které leží na cestě ke kořeni stromu kategorií od dané kategorie (#sub_cat_id) (0,M : 0,M) kategorie (#sub_cat_id)-s, které jsou potomky dané kategorie (#super_cat_id) v rámci stromu kategorií. (0,M : 0,M)

    Úkolem je vytvořit pro každou hlavní kategorii počet zboží. Přičemž zboží lze vystavovat pouze do listových kategorií.

    Moc děkuji za pomoc

    Odpovědi

    xkucf03 avatar 16.1.2021 22:21 xkucf03 | skóre: 50 | blog: xkucf03
    Rozbalit Rozbalit vše Re: SQL řešení hierarchické strukutury

    Co znamená:

    Úkolem je vytvořit pro každou hlavní kategorii počet zboží.

    ? Nemělo to být spíš zjistit počet nebo vypsat zboží v kategorii (včetně podkategorií)?

    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
    16.1.2021 23:37 Karlos
    Rozbalit Rozbalit vše Re: SQL řešení hierarchické strukutury
    Pouze počet zboží v rámci listu, tedy kategorie, která nemá další podkategorie.

    Řešení se našlo:
     INSERT INTO category (id, parent_category_Id)
     values (1,NULL);
      INSERT INTO category (id, parent_category_Id)
     values (2,NULL);
      INSERT INTO category (id, parent_category_Id)
     values (3,1);
      INSERT INTO category (id, parent_category_Id)
     values (4,2);
       INSERT INTO category (id, parent_category_Id)
     values (5,4);
       INSERT INTO category (id, parent_category_Id)
     values (6,4);
       INSERT INTO category (id, parent_category_Id)
     values (8,6);
      INSERT INTO category (id, parent_category_Id)
     values (9,NULL);
     
     
     WITH RECURSIVE cat_cte (id, parent_category_id, depth, top_parent) AS 
     (
     	select id, parent_category_id, 0, id as top_parent  
        FROM category
        where parent_category_id IS NULL
        UNION ALL
        select c.id, c.parent_category_id, cte.depth +1, cte.top_parent FROM category c INNER JOIN cat_cte cte
        on c.parent_category_id = cte.id
       
     ) select * from cat_cte cte;
     
    select * from category c left join category c2
    on c.id = c2.parent_category_id
    where c2.id IS NULL;
    
    Děkuji za vaši analýzu
    xkucf03 avatar 16.1.2021 23:41 xkucf03 | skóre: 50 | blog: xkucf03
    Rozbalit Rozbalit vše Re: SQL řešení hierarchické strukutury

    Upravil jsem formátování dotazu.

    Ano, to je CTE, o kterém píšu níže :-)

    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
    16.1.2021 23:59 Karlos
    Rozbalit Rozbalit vše Re: SQL řešení hierarchické strukutury
    Děkuji a děkuji za odkaz, skript mi udělal nějaký pán. Klasické CTE umím, ale rekurze a další věci ne, takže ještě učení bude dost. A ano je to do možná nové práce.
    16.1.2021 23:24 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: SQL řešení hierarchické strukutury
    Pokud strom kategorií nacpeš do jednoho XML, tak se s tím docela dobře pracuje - včetně prohledávání kategorií a vypisování drobenkové navigace.

    Na některé úlohy se prostě NoSQL hodí lépe.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    xkucf03 avatar 16.1.2021 23:38 xkucf03 | skóre: 50 | blog: xkucf03
    Rozbalit Rozbalit vše Re: SQL řešení hierarchické strukutury

    Počítám, že dostal úkol ve škole nebo v práci, takže potřebuje vyjít s tím, co má :-)

    Co se týče XML, to se dá vložit i do PostgreSQL a pak nad tím pustit XMLTABLE dotaz, který vypíše celou cestu (ID kategorií) nebo cokoli jiného.

    Pokud to má být čistě relačním způsobem, tak na to slouží CTE dotazy. Tady je o tom i článek v češtině: CTE a analytické funkce v PostgreSQL.

    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

    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.