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

    Nové číslo časopisu Raspberry Pi zdarma ke čtení: Raspberry Pi Official Magazine 161 (pdf).

    Ladislav Hagara | Komentářů: 0
    dnes 10:44 | Nová verze

    Po delší době vývoje vyšla nativní linuxová verze virtuálního bubeníka MT-PowerDrumKit 2 ve formátu VST3. Mezi testovanými hosty jsou Reaper, Ardour, Bitwig a Carla.

    balda | Komentářů: 1
    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ářů: 3
    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
    Které desktopové prostředí na Linuxu používáte?
     (8%)
     (4%)
     (0%)
     (9%)
     (20%)
     (3%)
     (5%)
     (3%)
     (11%)
     (49%)
    Celkem 381 hlasů
     Komentářů: 8, poslední 10.1. 23:18
    Rozcestník

    Dotaz: SQL dotaz, groupování

    24.7.2017 20:54 Franta
    SQL dotaz, groupování
    Přečteno: 1423×
    Mám sqlite databázi a následující tabulku, nazvěme ji tbl:
    |- id1 -|- id2 -|- min -|- max -|- pos -|-- set ---|
    |   0   |   0   |  10   |  20   |   0   |    0     |
    |   0   |   0   |   5   |  10   |   1   |    0     | Group1
    |--------------------------------------------------|
    |   0   |   0   |  15   |  25   |   0   |    1     | Group 2
    |--------------------------------------------------|
    |   0   |   0   |   5   |  15   |   0   |    2     | Group 3
    |-------|-------|-------|-------|-------|----------|
    |   0   |   1   |   5   |  10   |   0   |    0     |
    |   0   |   1   |   6   |  10   |   1   |    0     | Group4
    |-------|-------|-------|-------|-------|----------|
    |   1   |   0   |   5   |  10   |   0   |    0     |
    |   1   |   0   |   5   |  15   |   1   |    0     | Group5
    |   1   |   0   |  10   |  20   |   2   |    0     |
    
    Každá unikátní kombinace set, id1, id2 by měla představovat jednu skupinu.

    Ze skupiny potřebuji vybrat řádek, který má největší rozdíl min - max, zároveň nejmenší hodnotu pos.

    Nějak jsem napsal poddotaz. Píšu to teď z hlavy a asi to nebude funkční, něco takového:
    SELECT *
    FROM `tbl`
    `A`
    INNER JOIN
    ( SELECT `id1`, `id2`, `set`, MAX(`max` - `min`) as `delta`
      FROM `tbl`
      GROUP BY `id1`, `id2`, `set`
    ) `B`
    ON `A.id1` = `B.id1` AND `A.id2` = `B.id2` AND `A.set` = `B.set` AND (`A.max` - `A.min`) = `B.delta`
    
    Tento dotaz mi správně vrátí záznamy z každé skupiny s nejvyšším rozdílem max, min, tj:
    |- id1 -|- id2 -|- min -|- max -|- pos -|-- set ---|
    |   0   |   0   |  10   |  20   |   0   |    0     |
    |   0   |   0   |   5   |  10   |   1   |    0     | Group1
    |--------------------------------------------------|
    |   0   |   0   |  15   |  25   |   0   |    1     | Group 2
    |--------------------------------------------------|
    |   0   |   0   |   5   |  15   |   0   |    2     | Group 3
    |-------|-------|-------|-------|-------|----------|
    |   0   |   1   |   5   |  10   |   0   |    0     | Group4
    |-------|-------|-------|-------|-------|----------|
    |   1   |   0   |   5   |  15   |   1   |    0     | Group5
    |   1   |   0   |  10   |  20   |   2   |    0     |
    
    Z tohoto výsledku ještě potřebuji dostat řádky s nejnižší hodnotou pos v dané skupině. Tj. chci záznamy:
    |- id1 -|- id2 -|- min -|- max -|- pos -|-- set ---|
    |   0   |   0   |  10   |  20   |   0   |    0     | Group1
    |--------------------------------------------------|
    |   0   |   0   |  15   |  25   |   0   |    1     | Group 2
    |--------------------------------------------------|
    |   0   |   0   |   5   |  15   |   0   |    2     | Group 3
    |-------|-------|-------|-------|-------|----------|
    |   0   |   1   |   5   |  10   |   0   |    0     | Group4
    |-------|-------|-------|-------|-------|----------|
    |   1   |   0   |   5   |  15   |   1   |    0     | Group5
    
    Napadlo mě zduplikovat poddotaz, na jeden udělat poddotaz s agregační funkci MIN(pos) a provést další inner join na původní poddotaz na id1, id2, pos, ale nějak se mi to nezdá, nejde to udělat lépe?

    Odpovědi

    24.7.2017 20:57 Franta
    Rozbalit Rozbalit vše Re: SQL dotaz, groupování
    Tak dlouho jsem to upravoval, až je to špatně. Druhá tabulka po groupování má správně být
    |- id1 -|- id2 -|- min -|- max -|- pos -|-- set ---|
    |   0   |   0   |  10   |  20   |   0   |    0     | Group1
    |--------------------------------------------------|
    |   0   |   0   |  15   |  25   |   0   |    1     | Group 2
    |--------------------------------------------------|
    |   0   |   0   |   5   |  15   |   0   |    2     | Group 3
    |-------|-------|-------|-------|-------|----------|
    |   0   |   1   |   5   |  10   |   0   |    0     | Group4
    |-------|-------|-------|-------|-------|----------|
    |   1   |   0   |   5   |  15   |   1   |    0     | Group5
    |   1   |   0   |  10   |  20   |   2   |    0     |
    
    24.7.2017 22:09 K
    Rozbalit Rozbalit vše Re: SQL dotaz, groupování
    Ono to moc elegantně udělat nejde. Bohužel sqlite neumí window funkce, se kterými je to udělat hračka.

    Aby byl zápis jednodušší, tak si ještě můžes pomocí with - takhle nějak by to asi mohlo jít:
    with grupovane as (
    SELECT A.id1. A.id2, A.set, A.min, A.max, A.set
    FROM `tbl`
    `A`
    INNER JOIN
    ( SELECT `id1`, `id2`, `set`, MAX(`max` - `min`) as `delta`
      FROM `tbl`
      GROUP BY `id1`, `id2`, `set`
    ) `B`
    ON `A.id1` = `B.id1` AND `A.id2` = `B.id2` AND `A.set` = `B.set` AND (`A.max` - `A.min`) = `B.delta`
    (
    select * from grupovane C
    inner join
    (select id1, id2, set, min(pos) as minpos 
    from grupovane group bz id1, id2, set) d on C.id1 = D.id1 and `C.id2` = `D.id2` AND `C.set` = `D.set`
                  and C.pos = D.minpos
    
    takhle ale připojíš původní tabulku 4x. Navíc pokud budou nějaké záznamy, kde bude stejný rozdíl a stejný pos, tak ti to pro skupinu vrátí dva záznamy.

    Možná by to šlo řešit celkem elegantně aplikačně.
    select * from tbl order by id1, id2, set, max - min desc, pos
    
    a pak pro kombinaci id1, id2, set vzít vždy jen první řádek (pamatovat si hodnoty z minulého fetche a pokud se id1, id2 nebo set změní, tak je to řádek, co mě zajímá.

    25.7.2017 09:18 kaaja | skóre: 24 | blog: Sem tam něco | Podbořany, Praha
    Rozbalit Rozbalit vše Re: SQL dotaz, groupování
    Napadá mě takový workaround přístup. Potřebuješ vlastně najít řádek, pro který neexistuje žádný se stejnou kombinací id1, id2 a set, který má větší rozdíl v min a max, ale menší pos
    select * from tbl a 
    where not exists (
      select 0 from tbl b
       where a.id1 = b.id1 and a.id2 = b.id2 and a.set = b.set 
        and a.max - a.min < b.max - b.min and a.set > b.set
        and a.max <> b.max and a.min <> b.min
    )
    
    ale počítá to s tím, že neexistují úplně duplicitní řádky - ty to nevyselectí.
    Josef Kufner avatar 25.7.2017 11:41 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: SQL dotaz, groupování
    Můžeš to zkusit přepsat pomocí joinu (bez subselectu). Můžeš zkusit otočit ten join, který tam máš. Možná by to vyšlo trochu elegantněji. Ale v zásadě ten select se subselectem máš správně a o moc lépe to nejde.

    Pokud chceš ještě přidat podmínku na co nejmenší pos, tedy aby při stejném MAX(max-min) se vybralo menší pos, tak zkus rozdíl max-min a pos sloučit do jedné hodnoty a tím říct přesné pořadí – něco jako MAX((max - min) + (1 - pos/(SELECT MAX(pos) FROM tbl))) (předpokládám jen celočíselné sloupce). Pro lepší výkon by se mohlo hodit tuhle hodnotu předpočítávat do pomocného sloupečku a dát nad to index.
    Hello world ! Segmentation fault (core dumped)

    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.