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 23:33 | Nová verze

    Immich byl vydán v první stabilní verzi 2.0.0 (YouTube). Jedná se o alternativu k výchozím aplikacím od Googlu a Applu pro správu fotografií a videí umožňující vlastní hosting serveru Immich. K vyzkoušení je demo. Immich je součástí balíčků open source aplikací FUTO. Zdrojové kódy jsou k dispozici na GitHubu pod licencí AGPL-3.0.

    Ladislav Hagara | Komentářů: 0
    včera 22:33 | IT novinky

    Český telekomunikační úřad vydal zprávy o vývoji cen a trhu elektronických komunikací se zaměřením na rok 2024. Jaká jsou hlavní zjištění? V roce 2024 bylo v ČR v rámci služeb přístupu k internetu v pevném místě přeneseno v průměru téměř 366 GB dat na jednu aktivní přípojku měsíčně – celkově jich tak uživateli bylo přeneseno přes 18 EB (Exabyte). Nejvyužívanějším způsobem přístupu k internetu v pevném místě zůstal v roce 2024 bezdrátový

    … více »
    Ladislav Hagara | Komentářů: 0
    včera 12:11 | Nová verze

    Raspberry Pi OS, oficiální operační systém pro Raspberry Pi, byl vydán v nové verzi 2025-10-01. Přehled novinek v příspěvku na blogu Raspberry Pi a poznámkách k vydání. Jedná o první verzi postavenou na Debianu 13 Trixie.

    Ladislav Hagara | Komentářů: 0
    včera 05:22 | Nová verze

    Byla vydána nová verze 4.6 svobodného notačního programu MuseScore Studio (Wikipedie). Představení novinek v oznámení v diskusním fóru a také na YouTube.

    Ladislav Hagara | Komentářů: 0
    včera 02:22 | Komunita

    Společnost DuckDuckGo stojící za stejnojmenným vyhledávačem věnovala 1,1 milionu dolarů (stejně jako loni) na podporu digitálních práv, online soukromí a lepšího internetového ekosystému. Rozdělila je mezi 29 organizací a projektů. Za 15 let rozdala 8 050 000 dolarů.

    Ladislav Hagara | Komentářů: 4
    1.10. 20:11 | Nová verze

    Svobodný multiplatformní herní engine Bevy napsaný v Rustu byl vydán ve verzi 0.17. Díky 278 přispěvatelům.

    Ladislav Hagara | Komentářů: 0
    1.10. 16:11 | Nová verze

    Bylo vydáno openSUSE Leap 16 (cs). Ve výchozím nastavení přichází s vypnutou 32bitovou (ia32) podporou. Uživatelům však poskytuje možnost ji ručně povolit a užívat si tak hraní her ve Steamu, který stále závisí na 32bitových knihovnách. Změnily se požadavky na hardware. Leap 16 nyní vyžaduje jako minimální úroveň architektury procesoru x86-64-v2, což obecně znamená procesory zakoupené v roce 2008 nebo později. Uživatelé se starším hardwarem mohou migrovat na Slowroll nebo Tumbleweed.

    Ladislav Hagara | Komentářů: 3
    1.10. 16:00 | IT novinky

    Ministerstvo průmyslu a obchodu (MPO) ve spolupráci s Národní rozvojovou investiční (NRI) připravuje nový investiční nástroj zaměřený na podporu špičkových technologií – DeepTech fond. Jeho cílem je posílit inovační ekosystém české ekonomiky, rozvíjet projekty s vysokou přidanou hodnotou, podpořit vznik nových technologických lídrů a postupně zařadit Českou republiku mezi země s nejvyspělejší technologickou základnou.

    … více »
    Ladislav Hagara | Komentářů: 3
    1.10. 12:55 | Nová verze

    Radicle byl vydán ve verzi 1.5.0 s kódovým jménem Hibiscus. Jedná se o distribuovanou alternativu k softwarům pro spolupráci jako např. GitLab.

    Ladislav Hagara | Komentářů: 3
    1.10. 03:22 | IT novinky

    Společnost OpenAI představila text-to-video AI model Sora 2 pro generování realistických videí z textového popisu. Přesnější, realističtější a lépe ovladatelný než předchozí modely. Nabízí také synchronizované dialogy a zvukové efekty.

    Ladislav Hagara | Komentářů: 4
    Jaké řešení používáte k vývoji / práci?
     (41%)
     (47%)
     (15%)
     (16%)
     (18%)
     (14%)
     (17%)
     (14%)
     (14%)
    Celkem 158 hlasů
     Komentářů: 9, poslední 24.9. 17:28
    Rozcestník

    Dotaz: SQL řešení hierarchické strukutury

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