timescaledb/tsl/test/sql/compressed_collation.sql
Fabrízio de Royes Mello d602be4d81 PG16: Fix flaky test
In PG16 new collations named `en_US` and `en-US` on Windows bootstrap
that are incompatible with UTF-8. So added the `collencoding` to the
order of the query that determine the collation name to get another
compatible collation.
2023-11-08 15:26:42 -03:00

43 lines
1.6 KiB
SQL

-- This file and its contents are licensed under the Timescale License.
-- Please see the included NOTICE for copyright information and
-- LICENSE-TIMESCALE for a copy of the license.
\c :TEST_DBNAME :ROLE_SUPERUSER
-- We have different collation names such as en_US, en-US-x-icu and so on,
-- that are available on different platforms.
select * from (
select 3 priority, 'C' "COLLATION"
union all (select 2, collname from pg_collation where collname ilike 'en_us%' order by collencoding, collname limit 1)
union all (select 1, collname from pg_collation where collname ilike 'en_us_utf%8%' order by collencoding, collname limit 1)
) c
order by priority limit 1 \gset
create table compressed_collation_ht(time timestamp, name text collate :"COLLATION",
value float);
select create_hypertable('compressed_collation_ht', 'time');
alter table compressed_collation_ht set (timescaledb.compress,
timescaledb.compress_segmentby = 'name', timescaledb.compress_orderby = 'time');
insert into compressed_collation_ht values ('2021-01-01 01:01:01', 'á', '1'),
('2021-01-01 01:01:02', 'b', '2'), ('2021-01-01 01:01:03', 'ç', '2');
SELECT count(compress_chunk(ch)) FROM show_chunks('compressed_collation_ht') ch;
select ht.schema_name || '.' || ht.table_name as "CHUNK"
from _timescaledb_catalog.hypertable ht
inner join _timescaledb_catalog.hypertable ht2
on ht.id = ht2.compressed_hypertable_id
and ht2.table_name = 'compressed_collation_ht' \gset
create index on :CHUNK (name);
set enable_seqscan to off;
explain (costs off)
select * from compressed_collation_ht order by name;
select * from compressed_collation_ht order by name;