знаю, но с ним у меня проблема с "нулевой" датой (toDateTime(0)) - для Europe/Moscow возвращает 1970-01-02 вместо 1970-01-01.
а скажите зачем бывает надо делать toDateTime(0)? что за задача такая
лежит в таблице в качестве значения "дата отсутствует"
так и зачем тогда ее конвертить, если она отсутствует?
в этом поле лежат и реальные даты и к нему применяется toStartOfDay
я хочу натолкнуть на мысль, что вам надо эти данные отфильтровать или по другому обрабатывать. Раз у там логика заложена такая что данные должны интерпретирвоаться как несуществующие, то и для нулевых значений надо спец образом делать обработку с теми же if функциями или case/when
да это понятно, я думал, может есть какой более простой способ/функция это сделать
а сколько времени было в москве, когда в лондоне было 1970-01-01 00:00:00 ?
чет не очень понятно в чем проблема, надо 0 положить в колонку DateTime ?
Полагаю что 03:00:00
0 там уже лежит. проблема применить к нему toStartOfDay без дополнительных обвязок в виде if(...)
правильно т.е. когда в москве было 0:0:0, в лондоне было -3 часа, т.е. 0 - 3 * 3600
все равно не понимаю select toString(toDateTime(0), 'Europe/Moscow') 1970-01-01 03:00:00
Я тоже не понимаю, при чём тут toString? toStartOfDay(toDateTime(0)) -> '1970-01-02 00:00:00', почему 2-е?
это уже было недавно https://t.me/clickhouse_ru/344837
там, вроде как, речь про преобразование из Date, а тут всё в DateTime
суть одна, прочитайте ветку
ну возмжно вот такое сработает toDateTime(toDate(toDateTime(0))) а хотя это UTC получится, тоже самое что и toStartOfDay(toDateTime(0), 'UTC')
спасибо, попробую
Обсуждают сегодня