abclinuxu.cz AbcLinuxu.cz itbiz.cz ITBiz.cz HDmag.cz HDmag.cz abcprace.cz AbcPráce.cz
Inzerujte na AbcPráce.cz od 950 Kč
Rozšířené hledání
×
    dnes 22:33 | Nová verze

    Byla vydána dubnová aktualizace aneb nová verze 1.89 editoru zdrojových kódů Visual Studio Code (Wikipedie). Přehled novinek i s náhledy a animovanými gify v poznámkách k vydání. Vypíchnout lze, že v terminálu lze nově povolit vkládání kopírovaného textu stisknutím středního tlačítka myši. Ve verzi 1.89 vyjde také VSCodium, tj. komunitní sestavení Visual Studia Code bez telemetrie a licenčních podmínek Microsoftu.

    Ladislav Hagara | Komentářů: 0
    dnes 21:22 | Nová verze

    Proton, tj. fork Wine integrovaný v Steam Play a umožňující v Linuxu přímo ze Steamu hrát hry určené pouze pro Windows, byl vydán ve verzi 9.0-1 (𝕏). Přehled novinek se seznamem nově podporovaných her na GitHubu. Aktuální přehled her pro Windows běžících díky Protonu také na Linuxu na stránkách ProtonDB.

    Ladislav Hagara | Komentářů: 0
    dnes 19:33 | Nová verze

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

    Ladislav Hagara | Komentářů: 0
    dnes 11:22 | Bezpečnostní upozornění

    Služba Dropbox Sign (původně HelloSign) pro elektronické podepisování smluv byla hacknuta.

    Ladislav Hagara | Komentářů: 2
    dnes 11:00 | Nová verze

    Byla vydána nová major verze 8.0 textového editoru GNU nano (Wikipedie). Podrobný přehled novinek a oprav v oznámení v diskusním listu info-nano nebo v souboru ChangeLog na Savannah. Volbou --modernbindings (-/) lze povolit "moderní" klávesové zkratky: ^C kopírování, ^V vložení, ^Z vrácení zpět, … Tato volba je aktivována také pokud binárka s nano nebo link na ni začíná písmenem "e".

    Ladislav Hagara | Komentářů: 3
    včera 23:22 | IT novinky

    Před 60 lety, 1. května 1964, byl představen programovací jazyk BASIC (Beginners' All-purpose Symbolic Instruction Code).

    Ladislav Hagara | Komentářů: 12
    včera 22:22 | Nová verze

    Byla vydána nová verze 12.0 minimalistické linuxové distribuce (JeOS, Just enough Operating System) pro Kodi (dříve XBMC) a multimediálního centra LibreELEC (Libre Embedded Linux Entertainment Center). Jedná se o fork linuxové distribuce OpenELEC (Open Embedded Linux Entertainment Center). LibreELEC 12.0 přichází s Kodi 21.0 "Omega".

    Ladislav Hagara | Komentářů: 0
    včera 12:55 | Nová verze

    Microsoft vydal novou velkou aktualizaci 2404.23 v září 2019 pod licencí SIL Open Font License (OFL) zveřejněné rodiny písma Cascadia Code pro zobrazování textu v emulátorech terminálu a vývojových prostředích.

    Ladislav Hagara | Komentářů: 0
    včera 05:33 | Nová verze

    OpenTofu, tj. svobodný a otevřený fork Terraformu vzniknuvší jako reakce na přelicencování Terraformu z MPL na BSL (Business Source License) společností HashiCorp, bylo vydáno ve verzi 1.7.0. Přehled novinek v aktualizované dokumentaci. Vypíchnout lze State encryption.

    Ladislav Hagara | Komentářů: 0
    30.4. 23:55 | Humor

    Spouštět webový prohlížeč jenom kvůli nákupu kávy? Nestačí ssh? Stačí: ssh terminal.shop (𝕏).

    Ladislav Hagara | Komentářů: 20
    Podle hypotézy Mrtvý Internet mj. tvoří většinu online interakcí boti.
     (13%)
     (31%)
     (38%)
     (19%)
    Celkem 16 hlasů
     Komentářů: 3, poslední dnes 19:48
    Rozcestník

    Dotaz: prekryvanie datumov a medzery v intervaloch

    16.1. 14:12 jankoh
    prekryvanie datumov a medzery v intervaloch
    Přečteno: 852×
    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. 14:27 Vtipnéř | skóre: 38 | 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. 14:52 jankoh
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    2020-11-31? pre ktore id?
    xxxs avatar 16.1. 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. 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. 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. 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. 08:07 čavo | skóre: 13
    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. 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. 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. 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. 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. 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. 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. 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. 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. 00:04 jankoh
    Rozbalit Rozbalit vše Re: prekryvanie datumov a medzery v intervaloch
    mas pravdu, musim na to teda inak. dik.
    18.1. 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. 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. 11:06 cbrpnk | skóre: 8 | 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.