ClickHouse/tests/queries/0_stateless/01691_DateTime64_clamp.reference

28 lines
1.2 KiB
Plaintext
Raw Normal View History

-- { echo }
2021-02-27 11:21:31 +00:00
-- These values are within the extended range of DateTime64 [1925-01-01, 2284-01-01)
2021-02-22 17:44:24 +00:00
SELECT toTimeZone(toDateTime(-2, 2), 'Europe/Moscow');
2021-02-27 11:21:31 +00:00
1970-01-01 02:59:58.00
2021-02-22 17:44:24 +00:00
SELECT toDateTime64(-2, 2, 'Europe/Moscow');
2021-02-27 11:21:31 +00:00
1970-01-01 02:59:58.00
2021-02-22 17:44:24 +00:00
SELECT CAST(-1 AS DateTime64(0, 'Europe/Moscow'));
2021-02-27 11:21:31 +00:00
1970-01-01 02:59:59
2021-02-22 17:44:24 +00:00
SELECT CAST('2020-01-01 00:00:00.3' AS DateTime64(0, 'Europe/Moscow'));
2020-01-01 00:00:00
SELECT toDateTime64(bitShiftLeft(toUInt64(1), 33), 2, 'Europe/Moscow') FORMAT Null;
SELECT toTimeZone(toDateTime(-2., 2), 'Europe/Moscow');
1970-01-01 03:00:00.00
2021-02-22 17:44:24 +00:00
SELECT toDateTime64(-2., 2, 'Europe/Moscow');
1970-01-01 03:00:00.00
2021-02-22 17:44:24 +00:00
SELECT toDateTime64(toFloat32(bitShiftLeft(toUInt64(1),33)), 2, 'Europe/Moscow');
2021-02-27 11:21:31 +00:00
2106-02-07 09:28:16.00
2021-02-22 17:44:24 +00:00
SELECT toDateTime64(toFloat64(bitShiftLeft(toUInt64(1),33)), 2, 'Europe/Moscow') FORMAT Null;
Extended range of DateTime64 to years 1925 - 2238 The Year 1925 is a starting point because most of the timezones switched to saner (mostly 15-minutes based) offsets somewhere during 1924 or before. And that significantly simplifies implementation. 2238 is to simplify arithmetics for sanitizing LUT index access; there are less than 0x1ffff days from 1925. * Extended DateLUTImpl internal LUT to 0x1ffff items, some of which represent negative (pre-1970) time values. As a collateral benefit, Date now correctly supports dates up to 2149 (instead of 2106). * Added a new strong typedef ExtendedDayNum, which represents dates pre-1970 and post 2149. * Functions that used to return DayNum now return ExtendedDayNum. * Refactored DateLUTImpl to untie DayNum from the dual role of being a value and an index (due to negative time). Index is now a different type LUTIndex with explicit conversion functions from DatNum, time_t, and ExtendedDayNum. * Updated DateLUTImpl to properly support values close to epoch start (1970-01-01 00:00), including negative ones. * Reduced resolution of DateLUTImpl::Values::time_at_offset_change to multiple of 15-minutes to allow storing 64-bits of time_t in DateLUTImpl::Value while keeping same size. * Minor performance updates to DateLUTImpl when building month LUT by skipping non-start-of-month days. * Fixed extractTimeZoneFromFunctionArguments to work correctly with DateTime64. * New unit-tests and stateless integration tests for both DateTime and DateTime64.
2020-04-17 13:26:44 +00:00
-- These are outsize of extended range and hence clamped
SELECT toDateTime64(-1 * bitShiftLeft(toUInt64(1),35), 2);
1925-01-01 02:00:00.00
SELECT CAST(-1 * bitShiftLeft(toUInt64(1),35) AS DateTime64);
1925-01-01 02:00:00.000
SELECT CAST(bitShiftLeft(toUInt64(1),35) AS DateTime64);
2282-12-31 03:00:00.000
SELECT toDateTime64(bitShiftLeft(toUInt64(1),35), 2);
2282-12-31 03:00:00.00