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 04:44 | Komunita

    Ubuntu 26.10 bude Stonking Stingray (úžasný rejnok).

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

    Webový prohlížeč Dillo (Wikipedie) byl vydán ve verzi 3.3.0. S experimentální podporou FLTK 1.4. S příkazem dilloc pro ovládání prohlížeče z příkazové řádky. Vývoj prohlížeče se přesunul z GitHubu na vlastní doménu dillo-browser.org (Git).

    Ladislav Hagara | Komentářů: 1
    včera 21:55 | Komunita

    Byl publikován přehled dění a novinek z vývoje Asahi Linuxu, tj. Linuxu pro Apple Silicon. Vývojáři v přehledu vypíchli vylepšenou instalaci, podporu senzoru okolního světla, úsporu energie, opravy Bluetooth nebo zlepšení audia. Vývoj lze podpořit na Open Collective a GitHub Sponsors.

    Ladislav Hagara | Komentářů: 0
    25.4. 04:00 | Nová verze

    raylib (Wikipedie), tj. multiplatformní open-source knihovna pro vývoj grafických aplikací a her, byla vydána ve verzi 6.0.

    Ladislav Hagara | Komentářů: 0
    24.4. 18:33 | IT novinky

    Nové verze AI modelů. Společnost OpenAI představila GPT‑5.5. Společnost DeepSeek představila DeepSeek V4.

    Ladislav Hagara | Komentářů: 0
    24.4. 15:33 | Zajímavý článek

    Nová čísla časopisů od nakladatelství Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 164 (pdf) a Hello World 29 (pdf).

    Ladislav Hagara | Komentářů: 0
    24.4. 04:44 | Komunita

    Bylo oznámeno, že webový prohlížeč Opera GX zaměřený na hráče počítačových her je už také na Flathubu and Snapcraftu.

    Ladislav Hagara | Komentářů: 0
    23.4. 23:11 | IT novinky

    Akcionáři americké mediální společnosti Warner Bros. Discovery dnes schválili převzetí firmy konkurentem Paramount Skydance za zhruba 110 miliard dolarů (téměř 2,3 bilionu Kč). Firmy se na spojení dohodly v únoru. O část společnosti Warner Bros. Discovery dříve usilovala rovněž streamovací platforma Netflix, se svou nabídkou však neuspěla. Transakci ještě budou schvalovat regulační orgány, a to nejen ve Spojených státech, ale také

    … více »
    Ladislav Hagara | Komentářů: 0
    23.4. 22:33 | Nová verze

    Canonical vydal (email, blog, YouTube) Ubuntu 26.04 LTS Resolute Raccoon. Přehled novinek v poznámkách k vydání. Vydány byly také oficiální deriváty Edubuntu, Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu Cinnamon, Ubuntu Kylin, Ubuntu Studio, Ubuntu Unity a Xubuntu. Jedná se o 11. vydání s dlouhodobou podporou (LTS).

    Ladislav Hagara | Komentářů: 2
    23.4. 11:55 | Nová verze

    V programovacím jazyce Go naprogramovaná webová aplikace pro spolupráci na zdrojových kódech pomocí gitu Gitea (Wikipedie) byla vydána v nové verzi 1.26.0. Přehled novinek v příspěvku na blogu.

    Ladislav Hagara | Komentářů: 0
    Které desktopové prostředí na Linuxu používáte?
     (14%)
     (8%)
     (2%)
     (13%)
     (31%)
     (4%)
     (7%)
     (2%)
     (15%)
     (25%)
    Celkem 1428 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník

    Dotaz: postgresql - pomoc s dotazem (alternativa k procedure)

    29.1.2014 10:48 fesz
    postgresql - pomoc s dotazem (alternativa k procedure)
    Přečteno: 509×
    ahoj, laboruji tady s tabulkou:
     level |      full_path      
    -------+---------------------
         2 | {1,154}
         3 | {1,154,199}
         4 | {1,154,199,1037}
         4 | {1,154,199,2385}
         3 | {1,155,2359}
         4 | {1,155,2359,8}
         5 | {1,155,2359,8,1073}
    
    Z ni bych potreboval vydolovat radky:
         2 | {1,154}
         3 | {1,155,2359}
    
    tj. pokud jdu po radcich tabulky tak vysledkem jsou pouze radky kdyz je hodnota sloupce level mensi nez v predchozim radku (+ samozrejme prvni radek). Jedna se o prezentaci stromu v databazi a hledam hlavni uzly z tabulky.

    Napada me snadne reseni proceduralni, jednoduse projdu cyklem celou tabulku a budu porovnavat ten level. To mi prijde ale v databazich prasarna.

    Lze to prosim nejak resit primo dotazem?

    diky

    Řešení dotazu:


    Odpovědi

    Michy avatar 29.1.2014 11:09 Michy | skóre: 11 | Praha
    Rozbalit Rozbalit vše Re: postgresql - pomoc s dotazem (alternativa k procedure)
    To určitě lze jedním dotazem, jen je třeba do té tabulky přidat jeden sloupec, který by jednoznačně definoval pořadí řádků nebo přidat rovnou dva sloupce, jeden by byl unikátní id řádku a druhý by byl odkaz na id předchozího řádku. Jakmile je jednoznačně dané pořadí řádků, tak už není problém dosáhnout požadovaného efektu.
    29.1.2014 11:14 fesz
    Rozbalit Rozbalit vše Re: postgresql - pomoc s dotazem (alternativa k procedure)
    Ta tabulka co jsem posilal je vysledkem nejakych vetsich dotazu a je serazena podle full_path tj. jednoznacne poradi radku je dane. Jakym zpusobem to tedy lze resit?
    Řešení 1× (Michy)
    29.1.2014 11:18 fesz
    Rozbalit Rozbalit vše Re: postgresql - pomoc s dotazem (alternativa k procedure)
    tak uz asi tusim, spojit to pak samo se sebou a pak uz jen porovnavat level zda splnuje zminenou podminku
    29.1.2014 13:27 Pavel Stěhule
    Rozbalit Rozbalit vše Re: postgresql - pomoc s dotazem (alternativa k procedure)
    Selfjoin bude pro větší tabulky dost pomalý - rychlejší může být jednoduchá uložená funkce vracející tabulku - filtrování nad kurzorem nebo pak nějaká alchymie s window funkcemi. Selfjoin tak max pro stovky záznamů.
    29.1.2014 16:01 logik
    Rozbalit Rozbalit vše Re: postgresql - pomoc s dotazem (alternativa k procedure)
    SELECT * FROM (SELECT *, lag(level) over() as prev_level FROM tabulka) mezivysledek WHERE COALESCE(level > prev_level, True)

    Ale nezdá se mi, že to co chceš je to co opravdu chceš. Když budeš mít strom
     1 
    2 2
    Tak budeš chtít opravdu zobrazit jedničku a v případě, že první dvojka bude mít děti, druhou dvojku? To se mi zdá poměrně divným kritériem....

    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.