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 19:44 | IT novinky

    Microsoft představil Azure Linux 4.0 a Azure Container Linux. Na konferenci Open Source Summit North America 2026 organizované konsorciem Linux Foundation a sponzorované také Microsoftem. Azure Linux 4.0 vychází z Fedora Linuxu. Azure Container Linux je založen na projektu Flatcar. Azure Linux (GitHub, Wikipedie) byl původně znám jako CBL-Mariner.

    Ladislav Hagara | Komentářů: 0
    včera 12:22 | Zajímavý článek

    Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 165 (pdf).

    Ladislav Hagara | Komentářů: 0
    včera 10:55 | Nová verze

    Byla vydána verze 9.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a informačním videu.

    Ladislav Hagara | Komentářů: 4
    včera 09:33 | IT novinky

    Firefox 151 podporuje Web Serial API. Pro komunikaci s různými mikrokontroléry připojenými přes USB nebo sériové porty už není nutné spouštět Chrome nebo na Chromiu postavené webové prohlížeče.

    Ladislav Hagara | Komentářů: 6
    včera 04:44 | Nová verze

    Byla vydána nová stabilní verze 8.0 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 148. Přehled novinek i s náhledy v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    21.5. 21:33 | Bezpečnostní upozornění

    Ve FreeBSD byla nalezena a opravena zranitelnost FatGid aneb CVE-2026-45250. Jedná se o lokální eskalaci práv. Neprivilegovaný uživatel se může stát rootem.

    Ladislav Hagara | Komentářů: 0
    21.5. 14:33 | IT novinky

    Společnost Flipper Devices oznámila Flipper One. Zcela nový Flipper postavený od nuly. Jedná se o open-source linuxovou platformu založenou na čipu Rockchip RK3576. Hledají se dobrovolníci pro pomoc s dokončením vývoje (ovladače, testování, tvorba modulů).

    Ladislav Hagara | Komentářů: 2
    21.5. 14:00 | Nová verze

    Vývojáři Wine oznámili vydání verze 2.0 knihovny vkd3d pro překlad volání Direct3D na Vulkan. Přehled novinek na GitLabu.

    Ladislav Hagara | Komentářů: 0
    21.5. 11:33 | Nová verze

    Společnost Red Hat oznámila vydání Red Hat Enterprise Linuxu (RHEL) 10.2 a 9.8. Vedle nových vlastností a oprav chyb přináší také aktualizaci ovladačů a předběžné ukázky budoucích technologií. Vypíchnout lze CLI AI asistenta goose. Podrobnosti v poznámkách k vydání (10.2 a 9.8).

    Ladislav Hagara | Komentářů: 0
    21.5. 05:11 | Nová verze

    Organizace Apache Software Foundation (ASF) vydala verzi 30 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
    Které desktopové prostředí na Linuxu používáte?
     (12%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (7%)
     (3%)
     (16%)
     (26%)
    Celkem 1688 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: SQL řešení hierarchické strukutury

    16.1.2021 20:52 Karlos
    SQL řešení hierarchické strukutury
    Přečteno: 462×
    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.