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:55 | Zajímavý článek

    Uroš Popović v krátkém článku vysvětluje, co jsou emulátor terminálu, TTY a shell a jaké jsou mezi nimi rozdíly. Jde o první díl seriálu na jeho novém webu Linux Field Guide věnovaném nízkoúrovňové práci s linuxovými systémy.

    |🇵🇸 | Komentářů: 0
    16.5. 22:33 | Nová verze

    Byl vydán Debian 13.5, tj. pátá opravná verze Debianu 13 s kódovým názvem Trixie a Debian 12.14, tj. čtrnáctá opravná verze Debianu 12 s kódovým názvem Bookworm. Řešeny jsou především bezpečnostní problémy, ale také několik vážných chyb. Instalační média Debianu 13 a Debianu 12 lze samozřejmě nadále k instalaci používat. Po instalaci stačí systém aktualizovat.

    Ladislav Hagara | Komentářů: 0
    15.5. 12:55 | Nová verze

    CiviCRM (Wikipedie) bylo vydáno v nové verzi 6.14.0. Podrobnosti o nových funkcích a opravách najdete na release stránce. CiviCRM je robustní open-source CRM systém navržený speciálně pro neziskové organizace, spolky a občanské iniciativy. Projekt je napsán v jazyce PHP a licencován pod GNU Affero General Public License (AGPLv3). Český překlad má nyní 45 % přeložených řetězců a přibližuje se milníku 50 %. Potřebujeme vaši pomoc, abychom se dostali dál. Pokud máte chuť přispět překladem nebo korekturou, přidejte se na platformu Transifex.

    jardaIT | Komentářů: 3
    15.5. 12:22 | Bezpečnostní upozornění

    Další lokální zranitelností Linuxu je ssh-keysign-pwn. Uživatel si může přečíst obsah souborů, ke kterým má právo ke čtení pouze root, například soubory s SSH klíči nebo /etc/shadow. V upstreamu již opraveno [oss-security mailing list].

    Ladislav Hagara | Komentářů: 1
    14.5. 17:22 | Komunita

    Singularity (YouTube) je nejnovější otevřený film od Blender Studia. Jedná se o jejich první 4K HDR film.

    Ladislav Hagara | Komentářů: 9
    14.5. 16:55 | Zajímavý software

    Vyšla hra Život Není Krásný: Poslední Exekuce (Steam, ProtonDB). Kreslená point & click adventura ze staré školy plná černého humoru a nekorektního násilí. Vžijte se do role zpustlého exekutora Vladimíra Brehowského a projděte s ním jeho poslední pracovní den. Hra volně navazuje na sérii Život Není Krásný.

    Ladislav Hagara | Komentářů: 27
    14.5. 14:00 | Zajímavý projekt

    Společnost Red Hat představila Fedora Hummingbird, tj. linuxovou distribuci s nativním kontejnerovým designem určenou pro vývojáře využívající AI agenty.

    Pinhead | Komentářů: 6
    14.5. 02:22 | Zajímavý software

    Hru The Legend of Zelda: Twilight Princess od společnosti Nintendo si lze nově díky projektu Dusklight (původně Dusk) a reverznímu inženýrství zahrát i na počítačích a mobilních zařízeních. Vyžadována je kopie původní hry (textury, modely, hudba, zvukové efekty, …). Ukázka na YouTube. Projekt byl zahájen v srpnu 2020.

    Ladislav Hagara | Komentářů: 0
    14.5. 01:11 | Nová verze

    Byla vydána nová major verze 29.0 programovacího jazyka Erlang (Wikipedie) a související platformy OTP (Open Telecom Platform, Wikipedie). Detailní přehled novinek na GitHubu.

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

    Po zranitelnostech Copy Fail a Dirty Frag přichází zranitelnost Fragnesia. Další lokální eskalace práv na Linuxu. Zatím v upstreamu neopravena. Přiřazeno ji bylo CVE-2026-46300.

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

    Dotaz: Pomoct s funkcí v postgresql - minimum vybraného sloupce přes všechny tabulky ve schematu

    8.10.2015 00:44 MP
    Pomoct s funkcí v postgresql - minimum vybraného sloupce přes všechny tabulky ve schematu
    Přečteno: 1045×
    Dobrý den, Nevím jak udělat funkci, která by prošla všechny tabulky ve vybraném schématu a vrátila minimum sloupce. Všechny tabulky mají stejnou strukturu a stejně nazvané sloupce.

    Tabulky si vypíšu příkazem:

    SELECT tablename as nazev_tabulky FROM pg_catalog.pg_tables where schemaname='moje_schema'

    No a pak nevím jak udělat minimum vybraného sloupce přes všechny tabulky ve schématu, aby mi to vrátilo název tabulky a příslušnou hodnotu

    Řešení dotazu:


    Odpovědi

    8.10.2015 12:15 ttt
    Rozbalit Rozbalit vše Re: Pomoct s funkcí v postgresql - minimum vybraného sloupce přes všechny tabulky ve schematu
    Proč jsou ta data rozdělená do tabulek se stejnou strukturou? Udělejte z toho jednu tabulku, kde bude o jeden sloupec navíc, ve kterém bude současné jméno tabulky a podobné dotazy půjdou snadno.
    8.10.2015 13:34 Kit | skóre: 46 | Brno
    Rozbalit Rozbalit vše Re: Pomoct s funkcí v postgresql - minimum vybraného sloupce přes všechny tabulky ve schematu
    To je stará známá poučka, kterou začátečníci s oblibou ignorují. Musí si ještě párkrát nabít hubu, než pochopí její smysl.
    Komentáře označují místa, kde programátor udělal chybu nebo něco nedodělal.
    8.10.2015 15:08 MP
    Rozbalit Rozbalit vše Re: Pomoct s funkcí v postgresql - minimum vybraného sloupce přes všechny tabulky ve schematu
    Data jsou v samostatných tabulkách ze dvou důvodů:

    1) aby výsledná tabulka nebyla příliš velká. Tabulek je kolem stovky, každá má něco kolem milionu záznamů. Obecně ty tabulky nepotřebuji spojovat, a nejsou spolu nijak provázány

    2) Když ty tabulky updatuje paralelně několik klientů (8 konexi, každá updatuje jednu "malou" tabulku) tak nemusím řešit zamykání a podobné věci a mohu to dělat paralelně.

    8.10.2015 19:42 OldFrog {Ondra Nemecek} | skóre: 36 | blog: Žabákův notes | Praha
    Rozbalit Rozbalit vše Re: Pomoct s funkcí v postgresql - minimum vybraného sloupce přes všechny tabulky ve schematu
    Jasně, ale takto se to obvykle dělat nedoporučuje. Pokud to chcete mít čisté a máte možnost to upravovat, tak bych zvážil změnu - nejépe se poradit s někým, pro koho je návrh databáze denní chleba. Pokud je potřeba to nechat beze změny a jen na to napasovat zjištění těch minim, tak stačí ten union a bude to taky nějak fungovat. Nicméně do budoucna počítejte s komplikacemi a špatnou udržovatelností.
    -- OldFrog
    9.10.2015 00:39 MP
    Rozbalit Rozbalit vše Re: Pomoct s funkcí v postgresql - minimum vybraného sloupce přes všechny tabulky ve schematu
    Díky za info.. No změnu zvážím a s někým chytrým se poradím (dělám to tak jak umím, ne tak jak by se to mělo...) Myslel jsem si že nějaká pgsql funkce by to řešila, jenomže ji zatím neumím napsat. Toho unionu jsem se bál jelikož je tam moc tabulek
    okbob avatar 9.10.2015 07:10 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
    Rozbalit Rozbalit vše Re: Pomoct s funkcí v postgresql - minimum vybraného sloupce přes všechny tabulky ve schematu
    Zamykání si Postgres ošetří sám - paralelní UPDATE není problém. Zkuste se podívat na partitioning, jestli neřeší Váš problém.

    Jinak všechny informace potřebné pro automatickou iteraci jsou v systémovém katalogu.
    postgres=# do $$ -- iterace pres public a tabulky obsahujici sloupecek "c"
    declare 
      _table_name text; 
      _m int; _aux int; -- zde pouzit odpovidajici datovy typ
    begin
      for _table_name in 
         select table_name 
            from information_schema.columns
           where column_name = 'c' and table_schema = 'public'
       loop
         execute format('select max(%I) from %I.%I', 'c', 'public', _table_name) into _aux;
         _m := greatest(_m, _aux);
       end loop;
       raise notice 'maximum je %', _m;
    end; $$;
    NOTICE:  maximum je 100
    DO
    
    13.10.2015 22:46 MP
    Rozbalit Rozbalit vše Re: Pomoct s funkcí v postgresql - minimum vybraného sloupce přes všechny tabulky ve schematu
    Super, dík, to jsem potřeboval! Váš skript jsem trochu upravil (nepotřebuji maximum z maxim, ale z každé tabulky), a funguje to...
    okbob avatar 14.10.2015 07:01 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
    Rozbalit Rozbalit vše Re: Pomoct s funkcí v postgresql - minimum vybraného sloupce přes všechny tabulky ve schematu
    jasně - tohle byla jen ukázka, kterou jsem nechtěl komplikovat. A navíc bych Vám nechtěl upřít potěšení na to příjít sám :)
    8.10.2015 13:01 OldFrog {Ondra Nemecek} | skóre: 36 | blog: Žabákův notes | Praha
    Rozbalit Rozbalit vše Re: Pomoct s funkcí v postgresql - minimum vybraného sloupce přes všechny tabulky ve schematu
    Pokud můžete uvést názvy všech tabulek, pak snadno pomocí UNION přibližně takto:

    Vypsat minima z tabulek t1 a t2:
    ( SELECT min(c) AS c1 FROM t1 ) 
    UNION
    ( SELECT min(c) AS c1 FROM t2 )
    
    Vypsat nejmenší minimum:
    SELECT min(c1) FROM (
    
    ( SELECT min(c) AS c1 FROM t1 ) 
    UNION
    ( SELECT min(c) AS c1 FROM t2 )
    
    ) a;
    
    Důležité je nezapomenout pojmenovat odvozenou tabulku, v příkladu jsem pojmenoval jako "a".

    Pokud názvy tabulek předem neznáte, tak asi jedině pomocí SQL, které se předem vygenerujete. Pomocí procedury uložené v databázi anebo v programovacím jazyce, ze kterého sql dotaz spouštíte.
    -- OldFrog
    9.10.2015 11:19 Ivan
    Rozbalit Rozbalit vše Re: Pomoct s funkcí v postgresql - minimum vybraného sloupce přes všechny tabulky ve schematu
    Nebylo by lepsi "UNION ALL"?
    9.10.2015 11:20 Ivan
    Rozbalit Rozbalit vše Re: Pomoct s funkcí v postgresql - minimum vybraného sloupce přes všechny tabulky ve schematu
    Navic to min vlze hledat jen jednou na nejvyssi urovni.
    okbob avatar 9.10.2015 12:43 okbob | skóre: 30 | blog: systemakuv_blog | Benešov
    Rozbalit Rozbalit vše Re: Pomoct s funkcí v postgresql - minimum vybraného sloupce přes všechny tabulky ve schematu
    Pokud by nad sloupcem byl index, tak nejlepší metoda je minimum z minim - na "unionované" relaci se už nechytne index. Jinak 100% v tomto případě UNION ALL.
    9.10.2015 16:59 OldFrog {Ondra Nemecek} | skóre: 36 | blog: Žabákův notes | Praha
    Rozbalit Rozbalit vše Re: Pomoct s funkcí v postgresql - minimum vybraného sloupce přes všechny tabulky ve schematu
    Ano, UNION ALL, děkuju za korekci.
    -- OldFrog
    8.10.2015 18:22 jekub
    Rozbalit Rozbalit vše Re: Pomoct s funkcí v postgresql - minimum vybraného sloupce přes všechny tabulky ve schematu

    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.