1,9K прочтений · 2 года назад
Часовые пояса и относительность
Где кривизна, там фокусы со временем. Земля круглая, ее поверхность искривлена, и что же? Мы видим эффекты, очень похожие на те, что в теории относительности! В самом деле, каждой долготе присуще местное время, которое можно грубо определить так: полдень — это максимальная высота Солнца над горизонтом. Для простоты можно разделить круг на 24 часовых пояса. То есть в каждом поясе у людей объективно разное время: у одних утро, у других вечер, у третьих и вовсе ночь. Теперь смотрим на пилота, у которого умные часы всегда показывают местное время...
7 месяцев назад
💡Ответ💡 Правильные варианты - со 2 по 7. При конвертации UTC -> UTC+3 добавляется 3ч ко всем строкам, поэтому период начинается с 21:00 (UTC) = 00:00 (UTC+3) и заканчивается тоже в 21:00, потому что в between самое крайнее время - это не конец дня, а начало дня: --это одинаковые условия BETWEEN '2024-02-24' AND '2024-02-25' BETWEEN '2024-02-24 00:00:00' AND '2024-02-25 00:00:00' Зачем? 🍊Как-то раз мне нужно было проверить, долетают ли данные из одной системы в другую. Но каунты тотально не сходились. Потом я увидела, что день начинался в 21:00 предыдущего дня и заканчивался в 20:59 текущего. Так, разница в 3 часа, значит, связано с конвертацией дат в UTC - но это было не совсем так! 😜Много времени на выяснение обстоятельств, а суть заключалась в использовании идешки. Я работала в DBeaver, а когда написала тот же запрос в PyCharm - даты отображались корректно, с 00:00 до 23:59. Возможно, во всем виноваты настройки, но так и не получилось с ними разобраться. PyCharm люблю всей душой👩‍💻 Код потестить (ClickHouse):CREATE TABLE dates ( `datetime` datetime('UTC') ) ENGINE = MergeTree() ORDER BY datetime; INSERT INTO dates VALUES ('2024-02-23 20:59:00'), ('2024-02-23 21:00:00'), ('2024-02-23 23:59:00'), ('2024-02-24 00:00:00'), ('2024-02-24 02:59:00'), ('2024-02-24 20:59:00'), ('2024-02-24 21:00:00'), ('2024-02-24 22:00:00'), ('2024-02-25 00:00:00'), ('2024-02-25 02:59:00'); SELECT toDateTime(`datetime`, 'Europe/Moscow'), CASE WHEN toDateTime(`datetime`, 'Europe/Moscow') BETWEEN '2024-02-24' AND '2024-02-25' THEN 1 ELSE 0 END AS flag FROM dates ORDER BY 1;