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

    Desktopové prostředí Budgie bylo vydáno ve verzi 10.10. Dokončena byla migrace z X11 na Wayland. Budgie 10 vstupuje do režimu údržby. Vývoj se přesouvá k Budgie 11. Dlouho se řešilo, v čem bude nové Budgie napsáno. Budgie 10 je postaveno nad GTK 3. Přemýšlelo se také nad přepsáním z GTK do EFL. Budgie 11 bude nakonec postaveno nad Qt 6.

    Ladislav Hagara | Komentářů: 0
    včera 13:00 | Humor

    OpenChaos.dev je 'samovolně se vyvíjející open source projekt' s nedefinovaným cílem. Každý týden mohou lidé hlasovat o návrzích (pull requestech), přičemž vítězný návrh se integruje do kódu projektu (repozitář na GitHubu). Hlasováním je možné změnit téměř vše, včetně tohoto pravidla. Hlasování končí vždy v neděli v 9:00 UTC.

    NUKE GAZA! 🎆 | Komentářů: 2
    včera 03:00 | Nová verze

    Byl vydán Debian 13.3, tj. třetí opravná verze Debianu 13 s kódovým názvem Trixie a Debian 12.13, tj. třiná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
    10.1. 03:00 | Komunita

    Na stránkách Evropské komise, na portálu Podělte se o svůj názor, se lze do 3. února podělit o názor k iniciativě Evropské otevřené digitální ekosystémy řešící přístup EU k otevřenému softwaru.

    Ladislav Hagara | Komentářů: 6
    9.1. 19:44 | Zajímavý software

    Společnost Kagi stojící za stejnojmenným placeným vyhledávačem vydala (𝕏) alfa verzi linuxové verze (flatpak) svého proprietárního webového prohlížeče Orion.

    Ladislav Hagara | Komentářů: 5
    9.1. 19:11 | IT novinky

    Firma Bose se po tlaku uživatelů rozhodla, že otevře API svých chytrých reproduktorů SoundTouch, což umožní pokračovat v jejich používání i po plánovaném ukončení podpory v letošním roce. Pro ovládání také bude stále možné využívat oficiální aplikaci, ale už pouze lokálně bez cloudových služeb. Dokumentace API dostupná zde (soubor PDF).

    NUKE GAZA! 🎆 | Komentářů: 2
    9.1. 14:22 | Zajímavý článek

    Jiří Eischmann se v příspěvku na svém blogu rozepsal o open source AdGuard Home jako domácí ochraně nejen před reklamou. Adguard Home není plnohodnotným DNS resolverem, funguje jako DNS forwarder s možností filtrování. To znamená, že když přijme DNS dotaz, sám na něj neodpoví, ale přepošle ho na vybraný DNS server a odpovědi zpracovává a filtruje dle nastavených pravidel a následně posílá zpět klientům. Dá se tedy používat k blokování reklamy a škodlivých stránek a k rodičovské kontrole na úrovni DNS.

    Ladislav Hagara | Komentářů: 7
    9.1. 03:33 | Zajímavý software

    AI Claude Code od Anthropicu lépe rozumí frameworku Nette, tj. open source frameworku pro tvorbu webových aplikací v PHP. David Grudl napsal plugin Nette pro Claude Code.

    Ladislav Hagara | Komentářů: 1
    9.1. 00:11 | Nová verze

    Byla vydána prosincová aktualizace aneb nová verze 1.108 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.108 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    8.1. 20:44 | IT novinky

    Na lasvegaském veletrhu elektroniky CES byl předveden prototyp notebooku chlazeného pomocí plazmových aktuátorů (DBD). Ačkoliv se nejedná o první nápad svého druhu, nepochybně to je první ukázka praktického použití tohoto způsobu chlazení v běžné elektronice. Co činí plazmové chladící akční členy technologickou výzvou je především vysoká produkce jedovatého ozonu, tu se prý podařilo firmě YPlasma zredukovat dielektrickou

    … více »
    NUKE GAZA! 🎆 | Komentářů: 15
    Které desktopové prostředí na Linuxu používáte?
     (8%)
     (4%)
     (0%)
     (9%)
     (20%)
     (3%)
     (5%)
     (3%)
     (10%)
     (50%)
    Celkem 373 hlasů
     Komentářů: 8, poslední 10.1. 23:18
    Rozcestník

    Dotaz: Neumím použít agregační funkci

    25.11.2019 13:33 Paulus | skóre: 15 | Jihlava
    Neumím použít agregační funkci
    Přečteno: 1178×
    Dobrý den, z následující tabulky:

    Případ	STAVDO	CREATE_UZIVATEL	CASPREPNUTI
    První	SCHV	TUMJAN		2018-03-26T14:01:37.000+02:00
    První	SCHV	TUMJAN		2018-05-07T12:40:58.000+02:00
    První	SCHV	TUMJAN		2018-05-30T12:47:06.000+02:00
    První	SCHVAL	TUMJAN		2018-06-04T10:03:03.000+02:00
    První	SCHVAL	KULSVA		2018-08-10T15:29:15.000+02:00
    Druhý	SCHVAL	TUMJAN		2018-08-09T12:18:51.000+02:00
    Druhý	SCHV	TUMJAN		2018-10-19T13:02:11.000+02:00
    Druhý	SCHV	KULSVA		2018-11-23T14:09:05.000+01:00
    Druhý	SCHVAL	KULSVA		2018-11-26T13:27:18.000+01:00
    

    bych chtěl vybrat za každý Případ vybrat takové řádky, které mají minimální datum STAVDO. Na hodnotě atributů STAVDO a CREATE_UZIVATEL mi nezáleží. Očekávám tedy výstup:

    Případ	STAVDO	CREATE_UZIVATEL	CASPREPNUTI
    První	SCHV	TUMJAN		2018-03-26T14:01:37.000+02:00
    Druhý	SCHVAL	TUMJAN		2018-08-09T12:18:51.000+02:00
    

    Pokud použiju minimum na datum, nemohu použít group by na STAVDO a CREATE_UZIVATEL. Jak z toho ven? Díky moc za pomoc,

    Pavel Novák

    Řešení dotazu:


    Odpovědi

    Řešení 1× (Paulus (tazatel))
    xkucf03 avatar 25.11.2019 15:20 xkucf03 | skóre: 50 | blog: xkucf03
    Rozbalit Rozbalit vše Re: Neumím použít agregační funkci

    Pomocí window funkcí takto:

    #!/bin/bash
    
    data="Případ    STAVDO  CREATE_UZIVATEL CASPREPNUTI
    První   SCHV    TUMJAN          2018-03-26T14:01:37.000+02:00
    První   SCHV    TUMJAN          2018-05-07T12:40:58.000+02:00
    První   SCHV    TUMJAN          2018-05-30T12:47:06.000+02:00
    První   SCHVAL  TUMJAN          2018-06-04T10:03:03.000+02:00
    První   SCHVAL  KULSVA          2018-08-10T15:29:15.000+02:00
    Druhý   SCHVAL  TUMJAN          2018-08-09T12:18:51.000+02:00
    Druhý   SCHV    TUMJAN          2018-10-19T13:02:11.000+02:00
    Druhý   SCHV    KULSVA          2018-11-23T14:09:05.000+01:00
    Druhý   SCHVAL  KULSVA          2018-11-26T13:27:18.000+01:00";
    
    dotaz="SELECT případ, stavDo, create_uzivatel, casPrepnuti FROM (
            SELECT *, rank() OVER(PARTITION BY případ ORDER BY casPrepnuti) AS rank FROM csv
    ) WHERE rank = 1 ORDER BY případ DESC";
    
    echo "$data" \
            | sed  -E 's/\t+/,/g' \
            | relpipe-in-csv \
            | relpipe-tr-sql --relation "první_ve_skupině" "$dotaz" \
            | relpipe-out-tabular
    první_ve_skupině:
     ╭─────────────────┬─────────────────┬──────────────────────────┬───────────────────────────────╮
     │ Případ (string) │ STAVDO (string) │ CREATE_UZIVATEL (string) │ CASPREPNUTI          (string) │
     ├─────────────────┼─────────────────┼──────────────────────────┼───────────────────────────────┤
     │ První           │ SCHV            │ TUMJAN                   │ 2018-03-26T14:01:37.000+02:00 │
     │ Druhý           │ SCHVAL          │ TUMJAN                   │ 2018-08-09T12:18:51.000+02:00 │
     ╰─────────────────┴─────────────────┴──────────────────────────┴───────────────────────────────╯
    Record count: 2

    DBMS je musí podporovat (např. v SQLite je to až od 3.25.0).

    Případně v PostgreSQL to jde jednodušeji pomocí DISTINCT ON.

    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
    26.11.2019 11:11 Paulus | skóre: 15 | Jihlava
    Rozbalit Rozbalit vše Re: Neumím použít agregační funkci
    Funguje, jak má. Děkuji moc za pomoc.
    Řešení 1× (Paulus (tazatel))
    25.11.2019 19:26 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Neumím použít agregační funkci
    Bez window funkcí si musíte v jednom SELECTu seskupit řádky podle Případ a ke každé skupině vybrat minimální CASPREPNUTI. V druhém SELECTu vezmete tyhle dvojice (Případ + CASPREPNUTI) a ke každé z nich si donačtete zbývající údaje z řádku. A samozřejmě ty dva SELECTy nebudete provádět za sebou, ale spojíte je do jednoho, např. pomocí JOINu.
    SELECT * FROM table t
    JOIN
      (SELECT Případ, MIN(CASPREPNUTI) AS CASPREPNUTIFROM table GROUP BY Případ) g
      ON (t.Případ = g.Případ AND t.CASPREPNUTI= g.CASPREPNUTI)
    
    25.11.2019 19:28 Filip Jirsák | skóre: 67 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Neumím použít agregační funkci
    A ještě by bylo vhodné, aby na dvojici Případ + CASPREPNUTI byl unikátní index. Kdyby se v databázi vyskytla duplicita, vrátí vám v tom mém dotazu databáze všechny záznamy, které v té skupině nejmenší čas přepnutí, tj. měl byste tam skupinu duplicitně.
    26.11.2019 11:09 Paulus | skóre: 15 | Jihlava
    Rozbalit Rozbalit vše Re: Neumím použít agregační funkci
    Dobrý den,

    děkuji moc za pomoc. Něco takového jsem předpokládal, jen jsem nevěděl, jestli neexistuje snazší cesta.

    PN

    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.