SET datestyle = 'ISO'; -- Create servers for each engine. CREATE SERVER tz_bin_svr FOREIGN DATA WRAPPER clickhouse_fdw OPTIONS(driver 'binary'); CREATE USER MAPPING FOR CURRENT_USER SERVER tz_bin_svr; CREATE SERVER tz_http_svr FOREIGN DATA WRAPPER clickhouse_fdw OPTIONS(driver 'http'); CREATE USER MAPPING FOR CURRENT_USER SERVER tz_http_svr; SELECT clickhouse_raw_query('DROP DATABASE IF EXISTS tz_test'); SELECT clickhouse_raw_query('CREATE DATABASE tz_test'); SELECT clickhouse_raw_query($$ CREATE TABLE tz_test.ts ( id Int, server_ts DateTime, utc_ts DateTime('UTC'), nyc_ts DateTime('America/New_York'), lax_ts DateTime('America/Los_Angeles') ) ENGINE = MergeTree ORDER BY id $$); -- Insert some records, all times set to 10:00:00 UTC. SELECT clickhouse_raw_query($$ INSERT INTO tz_test.ts SELECT number, addMonths(toDateTime('2020-01-01 10:00:00', 'UTC'), number * 3), addMonths(toDateTime('2020-01-01 10:00:00', 'UTC'), number * 3), addMonths(toDateTime('2020-01-01 10:00:00', 'UTC'), number * 3), addMonths(toDateTime('2020-01-01 10:00:00', 'UTC'), number * 3) FROM numbers(0, 4) $$); SELECT clickhouse_raw_query($$ SELECT * FROM tz_test.ts ORDER BY id $$); CREATE SCHEMA tz_bin; IMPORT FOREIGN SCHEMA tz_test FROM SERVER tz_bin_svr INTO tz_bin; \d tz_bin.ts CREATE SCHEMA tz_http; IMPORT FOREIGN SCHEMA tz_test FROM SERVER tz_http_svr INTO tz_http; \d tz_http.ts SET session timezone = 'UTC'; SELECT * FROM tz_bin.ts ORDER BY id; SELECT * FROM tz_http.ts ORDER BY id; SET session timezone = 'America/New_York'; SELECT * FROM tz_bin.ts ORDER BY id; SELECT * FROM tz_http.ts ORDER BY id; SET session timezone = 'America/Los_Angeles'; SELECT * FROM tz_bin.ts ORDER BY id; SELECT * FROM tz_http.ts ORDER BY id; -- With parameters. Execute 6 times to get parameter passing to kick in. SET session timezone = 'UTC'; PREPARE prep_bin(int) AS SELECT * FROM tz_bin.ts WHERE id > $1; EXECUTE prep_bin(1); EXECUTE prep_bin(1); EXECUTE prep_bin(1); EXECUTE prep_bin(1); EXECUTE prep_bin(1); EXECUTE prep_bin(1); DEALLOCATE prep_bin; PREPARE prep_http(int) AS SELECT * FROM tz_http.ts WHERE id > $1; EXECUTE prep_http(1); EXECUTE prep_http(1); EXECUTE prep_http(1); EXECUTE prep_http(1); EXECUTE prep_http(1); -- Diff results < 28.8, due to https://github.com/ClickHouse/ClickHouse/issues/85847 EXECUTE prep_http(1); DEALLOCATE prep_http; -- Clean up. DROP USER MAPPING FOR CURRENT_USER SERVER tz_bin_svr; DROP SERVER tz_bin_svr CASCADE; DROP USER MAPPING FOR CURRENT_USER SERVER tz_http_svr; DROP SERVER tz_http_svr CASCADE;