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

    Canonical vydal (email, blog, YouTube) Ubuntu 24.04 LTS Noble Numbat. Přehled novinek v poznámkách k vydání a také příspěvcích na blogu: novinky v desktopu a novinky v bezpečnosti. Vydány byly také oficiální deriváty Edubuntu, Kubuntu, Lubuntu, Ubuntu Budgie, Ubuntu Cinnamon, Ubuntu Kylin, Ubuntu MATE, Ubuntu Studio, Ubuntu Unity a Xubuntu. Jedná se o 10. LTS verzi.

    Ladislav Hagara | Komentářů: 0
    dnes 14:22 | Komunita

    Na YouTube je k dispozici videozáznam z včerejšího Czech Open Source Policy Forum 2024.

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

    Fossil (Wikipedie) byl vydán ve verzi 2.24. Jedná se o distribuovaný systém správy verzí propojený se správou chyb, wiki stránek a blogů s integrovaným webovým rozhraním. Vše běží z jednoho jediného spustitelného souboru a uloženo je v SQLite databázi.

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

    Byla vydána nová stabilní verze 6.7 webového prohlížeče Vivaldi (Wikipedie). Postavena je na Chromiu 124. Přehled novinek i s náhledy v příspěvku na blogu. Vypíchnout lze Spořič paměti (Memory Saver) automaticky hibernující karty, které nebyly nějakou dobu používány nebo vylepšené Odběry (Feed Reader).

    Ladislav Hagara | Komentářů: 0
    dnes 04:55 | Nová verze

    OpenJS Foundation, oficiální projekt konsorcia Linux Foundation, oznámila vydání verze 22 otevřeného multiplatformního prostředí pro vývoj a běh síťových aplikací napsaných v JavaScriptu Node.js (Wikipedie). V říjnu se verze 22 stane novou aktivní LTS verzí. Podpora je plánována do dubna 2027.

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

    Byla vydána verze 8.2 open source virtualizační platformy Proxmox VE (Proxmox Virtual Environment, Wikipedie) založené na Debianu. Přehled novinek v poznámkách k vydání a v informačním videu. Zdůrazněn je průvodce migrací hostů z VMware ESXi do Proxmoxu.

    Ladislav Hagara | Komentářů: 0
    dnes 04:11 | Nová verze

    R (Wikipedie), programovací jazyk a prostředí určené pro statistickou analýzu dat a jejich grafické zobrazení, bylo vydáno ve verzi 4.4.0. Její kódové jméno je Puppy Cup.

    Ladislav Hagara | Komentářů: 0
    včera 22:44 | IT novinky

    IBM kupuje společnost HashiCorp (Terraform, Packer, Vault, Boundary, Consul, Nomad, Waypoint, Vagrant, …) za 6,4 miliardy dolarů, tj. 35 dolarů za akcii.

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

    Byl vydán TrueNAS SCALE 24.04 “Dragonfish”. Přehled novinek této open source storage platformy postavené na Debianu v poznámkách k vydání.

    Ladislav Hagara | Komentářů: 0
    včera 13:44 | IT novinky

    Oznámeny byly nové Raspberry Pi Compute Module 4S. Vedle původní 1 GB varianty jsou nově k dispozici také varianty s 2 GB, 4 GB a 8 GB paměti. Compute Modules 4S mají na rozdíl od Compute Module 4 tvar a velikost Compute Module 3+ a předchozích. Lze tak provést snadný upgrade.

    Ladislav Hagara | Komentářů: 0
    KDE Plasma 6
     (72%)
     (9%)
     (2%)
     (17%)
    Celkem 753 hlasů
     Komentářů: 4, poslední 6.4. 15:51
    Rozcestník

    Dotaz: Ukládání budoucích časů vs. letní čas

    Josef Kufner avatar 2.7.2011 11:29 Josef Kufner | skóre: 70
    Ukládání budoucích časů vs. letní čas
    Přečteno: 1224×
    Zrovna píšu jednu aplikaci, se kterou budou pracovat lidé v různých časových pásmech současně. Původně jsem si říkal, že bude stačit ukládat všechny časy v UTC a podle aktuálního nastavení časové zóny klienta ho správně přepočítávat. To lze celkem lehce v MySQL udělat použitím sloupců typu TIMESTAMP a nastavováním časového pásma per session (SET time_zone = '...').

    Ovšem narazil jsem na malou zákeřnost: Pokud uložím do databáze v zimě čas, který je v létě, tak až se na tento záznam podívám v létě, bude o hodinu posunut, protože jsem mezitím změnil časové pásmo z +1:00 na +2:00.

    Takže to takle jednoduché nebude.

    Jak tedy na to? Nevíte o nějakém ověřeném a jednoduchém způsobu používaném v kalendářích?

    Na webu je na toto téma hromada textu, ale prakticky všechny jsou dosti pochybné a často i zjevně chybné. Dokonce jsem našel i diskuze o chybě v Google Calendar týkající se letního času.

    Moje aplikace je klasické PHP 5.3 + MySQL, ale to není až tak podstatné.
    Hello world ! Segmentation fault (core dumped)

    Řešení dotazu:


    Odpovědi

    2.7.2011 12:24 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Něco je špatně. Buď to vy špatně používáte, nebo je chyba v MySQL. Když máte čas s časovou zónou, je jeho převod do jiné časové zóny vždy jednoznačný a není možné, aby se to přepočítávalo jednou správně a jednou špatně podle toho, zda je léto nebo zima. Letní a „zimní“ čas není nic jiného, než dvě časové zóny, mezi kterými se v konkrétní čas přepíná, a které představují pro danou oblast výchozí zónu, pokud se uvede čas bez uvedení zóny.

    Jinak v dokumentaci typů MySQL nevidím nic o časových zónách (že mě to u MySQL ani nepřekvapuje…), v MySQL Server Time Zone Support se píše, že timestamp se vždy ukládá v UTC a převádí se do aktuální časové zóny. Začal bych tedy tím, že se podíváte pomocí mysql klienta do databáze, zda tam ty časy máte správně a zda se správně převádí, když nastavíte různé časové zóny. Druhá věc je pak ještě zkontrolovat, jak se to chová v PHP, zda vám to náhodou nepřevádí mezi časovými zónami ještě podruhé.
    Jendа avatar 2.7.2011 12:53 Jendа | skóre: 78 | blog: Jenda | JO70FB
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Podle mě máš chybu v tom, že v zimě paušálně ode všech ukládaných časů odečítáš 2 a ke všem zobrazovaným přičítáš 2 a v létě to samé s 1. Správně bys měl nejdřív posoudit, jaký bude v tom ukládaném datu platit čas, a podle toho to teprve přepočítat (tj. když v lednu ukládám červenec 14 hodin, do databáze se uloží 12 hodin). Jediný problém, který mě napadá, je, jak se má aplikace zachovat, když jí někdo zadá v lokálním čase ten_podzimní_den 2:30.
    2.7.2011 13:53 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Pokud tam nějaké hodiny přičítá nebo odčítá, je problém v tom přičítání/odčítání :-) 13:00 TZ+2:00 == 12:00 TZ+1:00 == 11:00 UTC, žádné přičítání nebo odčítání není potřeba. Akorát je potřeba počítat s tím, že uživatel očekává časovou zónu platnou v době zadávaného času, ne aktuální – takže je potřeba časovou zónu přepínat podle zadávaného/čteného data, ne podle aktuálního data. Tj. pokud zadávám nebo čtu datum a čas v prosinci, musím nastavit časovou zónu SEČ, bez ohledu na to, zda je zrovna aktuální SEČ nebo SELČ. Při zadávání času mezi 2:00 a 3:00 při přechodu z letního času na standardní je asi potřeba se uživatele na časové pásmo dotázat, protože to nijak nevyvěštíte.
    Jendа avatar 2.7.2011 14:41 Jendа | skóre: 78 | blog: Jenda | JO70FB
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Akorát je potřeba počítat s tím, že uživatel očekává časovou zónu platnou v době zadávaného času, ne aktuální – takže je potřeba časovou zónu přepínat podle zadávaného/čteného data, ne podle aktuálního data.
    Jo, o to mi právě šlo. Jestli MySQL má tohle už nějak vyřešené, pak není co řešit. Z dotazu jsem nabyl dojmu, že si to přepočítávání píše sám.
    Josef Kufner avatar 2.7.2011 14:51 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Zatím ještě nepíšu (a ani nechci). Zjišťuju, jak se to dělá správně a trošku experimentuju.

    Zatím jsem ve stavu, kdy v PHP i MySQL nastavuju zónu na něco ve stylu "Europe/Prague" a používám sloupce typu TIMESTAMP. Ale nevím, zda to stačí a jestli tam nejsou schované nějaké problémy...
    Hello world ! Segmentation fault (core dumped)
    2.7.2011 17:06 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Nastavením časové zóny v PHP a MySQL ale určujete časovou zónu po aktuální čas. Vy ji ale potřebujete převádět vzhledem k datu a času, který ukládáte nebo zobrazujete. Když použijete aktuální časovou zónu, dopadne to tak, že uživatel teď zadá něco na prosinec 12:00 až 13:00, ale použije se aktuální časová zóna (tj. středoevropský letní čas), takže se to převede na 10:00 až 11:00 UTC. Až si to v prosinci zobrazí, bude aktuální „zimní“ čas a zobrazí se to jako 11:00 až 12:00 SEČ. To ale není chování, které uživatel očekává.
    Josef Kufner avatar 2.7.2011 17:20 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Já vím, proto tady tenhle dotaz je ;-)
    Hello world ! Segmentation fault (core dumped)
    2.7.2011 17:44 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    V tom případě ale nevím, na co se ptáte.
    2.7.2011 19:05 Sten
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Nevím konkrétně u PHP, ale MySQL a naprostá většina rozumných systémů nastavuje zónu geograficky a potom to funguje dobře pro zimní i letní čas, tj. pokud v létě použijete 24. prosince 13:00, bude to 12:00 UTC, a naopak pokud v zimě použijete 24. červen 14:00, bude to 12:00 UTC.
    2.7.2011 19:49 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    A pokud použiju 30. října 2011 2:30? Hádání časové zóny bez nápovědy uživatele obecně nemůže fungovat. Proto mají databáze, knihovny atd. pracovat vždy s dvojicí čas + časové pásmo, a pokud chce někdo časové pásmo hádat, měla by to dělat ta aplikace, která komunikuje s uživatelem. Ta jediná má dost informací a může se v případě potřeby zeptat.
    2.7.2011 20:28 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Pokud je řeč o časové zóně, tak ta už v sobě nese i informace o případném letním a zimním čase.
    2.7.2011 22:30 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    No právě. Takže teď uživatel zadá čas v SELČ, a v prosinci se mu zobrazí v SEČ, tedy o hodinu posunutý – když uživatel čas zadával, předpokládal totiž, že jej zadává v SEČ. Je tedy logické, aby aplikace uživateli vyšla vstříc a ten předpoklad splnila.
    3.7.2011 02:18 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Jen pokud je aplikace špatně napsaná. Pokud je napsaná správně, definice časové zóny obsahuje i informaci o tom, jaký je v daném okamžiku offset oproti UTC, takže se správně převede jak aktuální čas, tak jakýkoli čas v minulosti nebo budoucnosti (samozřejmě za předpokladu, že mezitím nedojde ke změně pravidel).
    3.7.2011 21:45 Filip Jirsák | skóre: 68 | blog: Fa & Bi
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Asi každý myslíme něco jiného časovou zónou. Já píšu o těch časových zónách, které jsou definovány posunem od UTC, takže třeba SEČ (+1 h.) nebo SELČ (+2 h.). Vy zřejmě píšete o časové zóně Evropa/Praha, která může být SEČ nebo SELČ, podle toho jak kdy.

    Problém je právě s určením toho časového okamžiku. Časový okamžik je určen právě časem a časovou zónou – když časová zóna chybí, může si aplikace něco domýšlet, ale to nebude vždy fungovat. I pokud dáme aplikaci také datum a aplikace bude mít pro daný rok správné údaje o přechodu na/z letní čas, pořád tam zbývá ta hodina při přechodu zpět na sluneční čas, kdy datum, čas a geografická časová zóna nestačí.
    3.7.2011 22:07 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Asi každý myslíme něco jiného časovou zónou.

    Očividně. Ale pokud se v souvislosti s unixovými systémy používá termín timezone (časová zóna), myslí se tím téměř vždy to, o čem mluvím já.

    pořád tam zbývá ta hodina při přechodu zpět na sluneční čas, kdy datum, čas a geografická časová zóna nestačí.

    Proto se také jako interní reprezentace používá ta vyjádřená pomocí time_t, která tímto problémem netrpí. A proto funkce mktime() v tom jednom speciálním případě přihlíží i k hodnotě položky tm_isdst; protože ale tento speciální případ (u většiny zón - z těch, které vůbec nějaký letní čas mají) pokrývá přibližně jednu setinu procenta roku (navíc pečlivě vybranou tak, aby se toho dělo pokud možno co nejméně), nikdo to obvykle moc neřeší.

    2.7.2011 14:53 Michal Kubeček | skóre: 72 | Luštěnice
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Ten časový okamžik se prostě musí převádět na interní reprezentaci jako celek - mimo jiné i proto, že pravidla pro letní čas se čas od času mění. Standardní knihovní funkce mktime() a localtime() resp. localtime_r() se o to postarají, otázkou jen je, jestli je autor software použije nebo jestli se spolehne na lidovou tvořivost.
    2.7.2011 13:35 Sten
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Nezadávejte zóny absolutně, ale geograficky:

    SET time_zone='Europe/Prague'

    Potom to funguje dobře.
    Josef Kufner avatar 2.7.2011 14:56 Josef Kufner | skóre: 70
    Rozbalit Rozbalit vše Re: Ukládání budoucích časů vs. letní čas
    Díky. Na tohle je potřeba importovat do MySQL data o zónách, což jsem předtím nějak minul...
    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.