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 12:33 | Komunita

    Alex Ellis upozornil 15. března, že firma Docker se chystala zrušit bezplatný hosting open-source projektů na Docker Hubu. Po vlně odporu se představitelé firmy omluvili a posléze byl původní záměr odvolán.

    Fluttershy, yay! | Komentářů: 0
    dnes 07:00 | IT novinky

    Ve věku 94 let zemřel Gordon Moore, mj. spoluzakladatel společnosti Intel a autor Moorova zákona.

    Ladislav Hagara | Komentářů: 0
    včera 17:11 | Nová verze

    Mercurial (Wikipedie), software pro SCM (Source Code Management), byl vydán ve verzi 6.4. Přehled novinek v poznámkách k vydání. Ve dnech 5. až 7. dubna proběhne konference Mercurial Paris.

    Ladislav Hagara | Komentářů: 0
    včera 11:55 | IT novinky

    Byly rozdány Ceny Velkého bratra (Big Brother Awards) za rok 2022 pro největší slídily pořádané nevládní organizací Iuridicum Remedium. Dlouhodobý slídil: Microsoft. Firemní slídil: Seznam. Úřední slídil: Nejvyšší správní soud. Výrok Velkého bratra: Marian Jurečka. Pozitivní cena: NoLog.

    Ladislav Hagara | Komentářů: 10
    včera 11:11 | Zajímavý projekt

    Byla představena online vzdělávací platforma Ada Computer Science pro učitele, studenty a kohokoli, kdo se zajímá o informatiku. Stojí za ní Raspberry Pi Foundation a Univerzita v Cambridgi.

    Ladislav Hagara | Komentářů: 0
    včera 09:11 | Bezpečnostní upozornění

    GitHub má nový RSA SSH klíč. Předchozí soukromý klíč byl krátce vystaven na GitHubu.

    Ladislav Hagara | Komentářů: 0
    včera 08:55 | IT novinky

    Společnost Framework Computer představila (YouTube) nové modulární notebooky: Laptop 13 s Intel Core nebo AMD Ryzen a Laptop 16 (YouTube).

    Ladislav Hagara | Komentářů: 0
    23.3. 19:33 | Nová verze

    Bylo vydáno Ubuntu 20.04.6 LTS, tj. šesté opravné vydání Ubuntu 20.04 LTS s kódovým názvem Focal Fossa. Přehled novinek v poznámkách k vydání a v přehledu změn.

    Ladislav Hagara | Komentářů: 2
    23.3. 14:44 | IT novinky

    Připojit neznámý USB flash disk do počítače může být nebezpečné. Dokonce může jít i o život. Někdo rozeslal ekvádorským novinářům USB flash disky, které po připojení do počítače explodují [BBC, Twitter].

    Ladislav Hagara | Komentářů: 2
    23.3. 13:33 | Nová verze

    Byla vydána nová verze 7.4 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 v informačním videu.

    Ladislav Hagara | Komentářů: 0
    Používáte WSL (Windows Subsystem for Linux)?
     (74%)
     (12%)
     (4%)
     (10%)
    Celkem 318 hlasů
     Komentářů: 4, poslední včera 06:42
    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: 476×
    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.