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 21:11 | Nová verze

    Byl vydán Debian 13 s kódovým názvem Trixie. Přehled novinek v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 2
    včera 15:55 | Zajímavý software

    WLED je open-source firmware pro ESP8266/ESP32, který umožňuje Wi-Fi ovládání adresovatelných LED pásků se stovkami efektů, synchronizací, audioreaktivním módem a Home-Assistant integrací. Je založen na Arduino frameworku.

    Indiánský lotr | Komentářů: 0
    8.8. 15:33 | Nová verze

    Open source platforma Home Assistant (Demo, GitHub, Wikipedie) pro monitorování a řízení inteligentní domácnosti byla vydána v nové verzi 2025.8.

    Ladislav Hagara | Komentářů: 6
    8.8. 14:22 | IT novinky

    Herní studio Hangar 13 vydalo novou Mafii. Mafia: Domovina je zasazena do krutého sicilského podsvětí na začátku 20. století. Na ProtonDB je zatím bez záznamu.

    Ladislav Hagara | Komentářů: 1
    8.8. 13:22 | IT novinky

    Operátor O2 má opět problémy. Jako omluvu za pondělní zhoršenou dostupnost služeb dal všem zákazníkům poukaz v hodnotě 300 Kč na nákup telefonu nebo příslušenství.

    Ladislav Hagara | Komentářů: 8
    8.8. 05:55 | IT novinky

    Společnost OpenAI představila GPT-5 (YouTube).

    Ladislav Hagara | Komentářů: 2
    8.8. 05:00 | Nová verze

    Byla vydána (𝕏) červencová aktualizace aneb nová verze 1.103 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a videi v poznámkách k vydání. Ve verzi 1.103 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    7.8. 17:33 | IT novinky

    Americký prezident Donald Trump vyzval nového generálního ředitele firmy na výrobu čipů Intel, aby odstoupil. Prezident to zdůvodnil vazbami nového šéfa Lip-Bu Tana na čínské firmy.

    Ladislav Hagara | Komentářů: 10
    7.8. 16:55 | Nová verze

    Bylo vydáno Ubuntu 24.04.3 LTS, tj. třetí opravné vydání Ubuntu 24.04 LTS s kódovým názvem Noble Numbat. Přehled novinek a oprav na Discourse.

    Ladislav Hagara | Komentářů: 0
    7.8. 16:44 | Nová verze

    Byla vydána verze 1.89.0 programovacího jazyka Rust (Wikipedie). Podrobnosti v poznámkách k vydání. Vyzkoušet Rust lze například na stránce Rust by Example.

    Ladislav Hagara | Komentářů: 0
    Kolik tabů máte standardně otevřeno ve web prohlížeči?
     (46%)
     (20%)
     (4%)
     (5%)
     (3%)
     (1%)
     (1%)
     (18%)
    Celkem 319 hlasů
     Komentářů: 23, poslední 4.8. 13:01
    Rozcestník

    Dotaz: postgres a maximum z několika sloupečků

    10.3.2006 21:04 Jáchym Čepický | skóre: 29 | blog: U_Jachyma
    postgres a maximum z několika sloupečků
    Přečteno: 86×
    zdravím,

    potřeboval bych dostat pro každý záznam jméno sloupce, který má maximální hodnotu z několika dalších: tedy pro každý zázam *lesního porostu* získat jméno *dřeviny*, která se v danném porostu vyskytuje nejčastěji:
    id_porostu | sm | bk | jd | max
    -----------+----+----+----+-----
         1     | 100| 0  | 0  | sm
         2     | 30 | 50 | 20 | bk
         3     | 90 | 5  | 5  | sm
         4     | 30 | 30 | 40 | jd
    ...
    
    nevíte prosím někdo, jak na to, ať už pomocí sql a nebo skriptem?

    dík

    jáchym

    Odpovědi

    10.3.2006 22:24 Jáchym Čepický | skóre: 29 | blog: U_Jachyma
    Rozbalit Rozbalit vše Re: postgres a maximum z několika sloupečků
    jde to , ale dře to:
    import os, string, sys
    
    for line in os.popen("""psql -tA -F " " -d databaze -c "select id_porostu,sm,bo,jd,md,dg,bk,db,js,jv,lp FROM det" """):
        if len(line.split()) == 11:
            #[id,sm,bo,jd,md,dg,bk,db,js,jv,lp] = line.split()
            line=line.split()
            dreviny=[]
            for strom in line:
                dreviny.append(string.atoi(strom))
                
            maximum=max(dreviny[1:])
            result = {
                 dreviny[1]: 'spruce',
                 dreviny[2]: 'pine',
                 dreviny[3]: 'fir',
                 dreviny[4]: 'larch',
                 dreviny[5]: 'douglas',
                 dreviny[6]: 'beach',
                 dreviny[7]: 'oak',
                 dreviny[8]: 'beach',
                 dreviny[9]: 'maple',
                 dreviny[10]: 'oak'
            }[maximum]
            #sys.stdout=sys.stderr
            print """update det set baumart='%s' where id_porostu=%d;\n""" % (result, dreviny[0])
    
    10.3.2006 22:27 secido | skóre: 27
    Rozbalit Rozbalit vše Re: postgres a maximum z několika sloupečků
    Pekne, ale co tak trochu sa zamysliet nad navrhom tabulky?
    11.3.2006 01:24 Pmx
    Rozbalit Rozbalit vše Re: postgres a maximum z několika sloupečků
    Co když budou mít dva sloupce stejný (a nejvyšší) obsah? Jinak ten skript mi přijde docela fuj, snad by to šlo vyřešit přes SQL v nějakém pohledu (view), tzn. přímo do tabulky to vůbec netahat.
    11.3.2006 10:19 barney
    Rozbalit Rozbalit vše Re: postgres a maximum z několika sloupečků
    view? ee

    ale slo by to snad cez pl/pgsql

    11.3.2006 10:41 Jáchym Čepický | skóre: 29 | blog: U_Jachyma
    Rozbalit Rozbalit vše Re: postgres a maximum z několika sloupečků
    Pánové. Díky za vaše rady skutečně nad zlato. Neptal jsem se "čím", ale ptal jsem se "jak". Kdybyste alespoň zveřejnili "hezčí" verzi skriptu (v pythonu začínám).

    Add návrh tabulky .. možná je špatný, ale nic lepšího mě nanapadá. Ostatně nejsem autor, dělám s tím, co jsem dostal.

    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.