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 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ářů: 2
    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ářů: 5
    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
    13.5. 14:00 | Komunita

    Sovereign Tech Agency (Wikipedie) prostřednictvím svého fondu Sovereign Tech Fund podpoří KDE částkou 1 285 200 eur.

    Ladislav Hagara | Komentářů: 13
    Které desktopové prostředí na Linuxu používáte?
     (13%)
     (8%)
     (2%)
     (14%)
     (31%)
     (4%)
     (6%)
     (3%)
     (16%)
     (26%)
    Celkem 1643 hlasů
     Komentářů: 30, poslední 3.4. 20:20
    Rozcestník
    Štítky: není přiřazen žádný štítek

    Dotaz: prekryvanie datumov a medzery v intervaloch

    16.1.2024 14:12 jankoh
    prekryvanie datumov a medzery v intervaloch
    Přečteno: 3808×
    zdravim,

    pre zjednodusenie majme nasledujucu tabulku:
    insert into hodnoty (id,hodnota,datum_od,datum_do) values
    	 (1,3.300,'2018-01-01','2019-12-31'),
    	 (1,3.600,'2020-01-01','2020-11-31'),
    	 (1,3.850,'2021-01-01','2021-12-31'),
    	 (1,4.000,'2022-01-01','2022-12-31'),
    	 (1,4.350,'2023-01-01','2023-12-31'),
    	 (1,4.700,'2024-01-01','3333-03-03'),
    	 (2,3.300,'2018-01-01','2019-12-31'),
    	 (2,3.600,'2020-01-01','2020-12-31'),
    	 (2,3.850,'2021-01-01','2021-12-31'),
    	 (2,4.000,'2022-01-01','2022-12-31');
    	 (2,4.350,'2023-01-01','2023-12-31'),
    	 (2,4.700,'2024-01-01','3333-03-03'),
    	 (3,2.848,'2018-01-01','2018-08-31'),
    	 (3,2.943,'2018-09-01','2018-12-31'),
    	 (3,3.188,'2019-01-01','2019-12-31'),
    	 (3,3.555,'2020-01-01','2020-12-31'),
    	 (3,3.819,'2020-12-01','2021-12-31'),
    	 (3,3.961,'2022-01-01','2022-12-31'),
    	 (3,4.291,'2023-01-01','2023-12-31'),
    	 (3,4.597,'2024-01-01','3333-03-03');
    
    su v nej id ktore maju urcitu casovu platnost. je mozne priamo v sql zistit, ci sa pre jednotlive id datumove intervaly neprekryvaju(t.j. ci id nema v dany datum viacero moznych hodnot) a zaroven ci nie su v intervaloch medzery(t.z. ci neexistuje datum pre ktory id nema ziadnu hodnotu)?

    v priklade ako najmensi mozny datum je 2018-01-01 a najvyssi 3333-03-03.

    pre id=1 napr. chybaju hodnoty pre december 2020. pre id=3 su zase pre interval datumov december 2020 platne 2 hodnoty(3.555 aj 3.819 co je nespravne).

    je mozne tieto chyby v integrite dat nejako lahko vyselektovat?

    dakujem.

    Odpovědi

    16.1.2024 14:27 Vtipnéř | skóre: 39 | blog: Vtipnéřův blog | Brno
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    Taky je tam neexistující datum '2020-11-31', to by se mělo taky zjistit?
    Opening Windows is better than washing them. Clearing Windows (e.g. erasing or deleting) is even much better.
    16.1.2024 14:52 jankoh
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    2020-11-31? pre ktore id?
    xxxs avatar 16.1.2024 20:09 xxxs | skóre: 25 | blog: vetvicky
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    druhy zaznam: (1,3.600,'2020-01-01','2020-11-31'),
    16.1.2024 20:19 X
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    Je to jen vzorovy nastrel => je to uplne jedno.
    xxxs avatar 16.1.2024 20:25 xxxs | skóre: 25 | blog: vetvicky
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    pytal sa na to, tak dostal odpoved.
    16.1.2024 20:28 jankoh
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    no tak konkretne ten datum 2020-11-31 interval od 2020-01-01 do 2020-11-31 pokryva ci nie? pre id=1 chyba cely december(cize od 2020-12-01 do 2020-12-31), ale to som pisal v zadani.
    17.1.2024 08:07 čavo | skóre: 16
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    Tak otázka bola, či sa majú detegovať aj neexistujúce dátumy, lebo jedenásty mesiac má len 30 dní.
    17.1.2024 21:21 jankoh
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    ahaaa...jasne, to je moja chyba v zadani, to som prehliadol. taketo chyby to hladat nemusi, predpoklad je, ze datumove intervaly su zadane korektne a db nedovoli zapisat neexistujuci datum.
    16.1.2024 20:32 jankoh
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    asi to nema priamo v sql nejake jednoduche riesenie, asi bude pohodlnejsie exportnut data a tu kontolou vykonat v nejakom python scripte.
    xxxs avatar 16.1.2024 20:48 xxxs | skóre: 25 | blog: vetvicky
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    asi. mozno by sa to dalo v sql rozbit na jednotlive datumy k danemu id. potom by si vedel najst duplicity a porovnanim s tabulkou s komletnymi datumami by si videl, co ti chyba.
    16.1.2024 21:43 X
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    Nesla by pouzit na kazdy sloupec LAG() funkce? Co je to vubec za databazovy system?
    16.1.2024 22:35 jankoh
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    mariadb. ale v podstate mi slo o univerzalne pouzitelne riesenie.

    za ten LAG() dik, zajtra to preskumam podrobnejsie, ale mohol by to byt spravny smer.

    medzitym ma napadlo take primitivne riesenie: pouzit viacere docasne tabulky. do jednej si vypocitat na zaklade min(datum_od) a max(datum_do) pre kazde id celkovy pocet dni. do druhej si pre kazde id vypocitat pocet dni pre kazdy interval a spravit sum() jednotlivych intervalov. a potom porovnat. ak sa rovnaju tak je to ok. ak celkovy pocet dni bude vacsi ako sucet intervalov tak nejaky datum chyba, ak mensi tak sa prekryvaju.
    17.1.2024 01:12 ttttttttttt
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    Překrývající intervaly můžeš najít tak, že vyzkoušíš všechny dvojice, jestli se překrývají. Dá se to udělat i líp, tohle je spíš na jednorázový test.
    select *
    from 
      hodnoty h1
      join hodnoty h2 on daterange(h1.datum_od, h1.datum_do, '[]') && daterange(h2.datum_od, h2.datum_do, '[]') and h1.id < h2.id;
    A jestli něco nechybí můžeš zjistit tak, že porovnáš součty délek intervalů s intervalem (nejmenší datum, největší). V mariadb možná bude potřeba napsat vlastní podmínky na porovnání intervalů, nevím, jestli je tam na to funkce.
    17.1.2024 21:12 jankoh
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    mozno primitivne, ale funkcne riesenie. davam to sem, ak by to niekto povazoval za uzitocne.
    with t1 as(
      select
        id,
        datediff(max(datum_do), min(datum_od)) + 1 as celkovy_pocet_dni
      from
        hodnoty
      group by
        id
    ),
    t2 as(
      select
        id,
        sum(datediff(datum_do, datum_od) + 1) as sucet_intervalov
      from
        hodnoty
      group by
        id
    ),
    t3 as (
      select
        t1.id as id,
        celkovy_pocet_dni - sucet_intervalov as rozdiel
      from
        t1
        left join t2 on t2.id = t1.id
      having
        rozdiel != 0
    )
    select
      id,
      case
        when rozdiel < 0 then 'duplicita datumov'
        when rozdiel > 0 then 'chybajuci interval datumov'
      end as chyba
    from
      t3
    order by
      t3.id
    
    17.1.2024 23:22 tttttttttttt
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    Tohle jen kontroluje, že celková délka souhlasí, ale překryvy / chybějící dny to neodhalí. Součet může sedět, i když se intervaly překrývají:
    (1,1.000,'2018-01-01','2018-12-31'),
    (1,1.000,'2018-01-01','2018-12-31'),
    (1,1.000,'2020-01-01','2020-12-31')
    18.1.2024 00:04 jankoh
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    mas pravdu, musim na to teda inak. dik.
    18.1.2024 18:41 jankoh
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    -- kontrola ci datum_do nie je mensi ako datum_od
    select
      *,
      datediff(h.datum_do, h.datum_od) as pocet_dni
    from
      hodnoty as h
    having
      pocet_dni < 0
    order by
      h.id,
      h.datum_od,
      h.datum_do;
    
    -- kontrola ci intervaly datumov na seba plynulo nadvazuju
    with t1 as (
      select
        h.id,
        lag(h.datum_do, 1) over (
          PARTITION BY h.id
          order by
            h.id,
            h.datum_od,
            h.datum_do
        ) as datum_pred,
        h.datum_od,
        h.datum_do,
        lead(h.datum_od, 1) over (
          PARTITION BY h.id
          order by
            h.id,
            h.datum_od,
            h.datum_do
        ) as datum_po
      from
        hodnoty as h
      order by
        h.id,
        h.datum_od,
        h.datum_do
    )
    select
      id,
      datum_pred,
      case
        when datediff(datum_od, datum_pred) is NULL then 'OK'
        when datediff(datum_od, datum_pred) = 1 then 'OK'
        else 'CHYBA'
      end as stav_1,
      datum_od,
      datum_do,
      case
        when datediff(datum_po, datum_do) is NULL then 'OK'
        when datediff(datum_po, datum_do) = 1 then 'OK'
        else 'CHYBA'
      end as stav_2,
      datum_po
    from
      t1
    having
      stav_1 = 'CHYBA'
      or stav_2 = 'CHYBA'
    
    skusil som to vyriesit pomocou LAG a LEAD. rozdelil som to do dvoch krokov. najskor sa skontroluje ci su v poriadku jednotlive datumove intervaly. a v druhom kroku sa skontroluje ci intervaly pre jednotlive id na seba nadvazuju a neprekryvaju sa. vie mi to niekto skontrolovat ci tam zase nie je nejaka chyba? nejaky pripad pri ktorom by kontrola zlyhala?
    18.1.2024 22:25 Tomas
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    překryvy:
    select 
       A.*
       ,B.*
    from hodnoty A
    join hodnoty B on A.id = b.id and A.datum_do >= B.datum_od and A.datum_od <= B.datum_do
    

    řešení vychází z následujícího obrázku, který ukazuje možné překryvy

                A
        +----------------+
        o                x
     o     x  o    x  o     x
     +-----+  +----+  +-----+
        B       B        B
    

    Díry v jistém smyslu jsou problematičtější, protože vždycky budete mít díru. A to na začátku a na konci.

    select
      A.*
      ,min(B.datum_od)
    from hodnoty A
    join hodnoty B on A.id = B.id and A.datum_do < B.datum_od
    group by A.*
    having A.datum_do + interval '1' day < min(B.datum_od)
    

    Rychlejší řešení děr je pomocí analytických funkcí. Konkrétně funkce LAG a LEAD

    cbrpnk avatar 13.2.2024 11:06 cbrpnk | skóre: 10 | blog: bl0gium
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    SELECT id, hodnota, datum_od, datum_do
    FROM (
       SELECT id, hodnota, datum_od, datum_do,
              LEAD(datum_od) OVER (PARTITION BY id ORDER BY datum_od) AS next_datum_od
       FROM hodnoty
    ) AS t
    WHERE datum_do >= next_datum_od; 
    
    SELECT id, hodnota, datum_od, datum_do
    FROM (
      SELECT id, hodnota, datum_od, datum_do,
             LAG(datum_do) OVER (PARTITION BY id ORDER BY datum_od) AS prev_datum_do
      FROM hodnoty
    ) AS t
    WHERE datum_od > DATE_ADD(prev_datum_do, INTERVAL 1 DAY);
    

    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.