1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116
|
# name: test/sql/collate/test_collation_propagation.test
# description: Test collations with string functions.
# group: [collate]
statement ok
create table tbl (a varchar, b varchar);
statement ok
insert into tbl values ('ö', '>>>>>ö<<<<<'), ('o', '>>>>>o<<<<<'), ('p', '>>>>>p<<<<<');
query I
select a from tbl where contains(b collate nocase, 'O') order by all
----
o
# test propagation of collation through string functions
query I
select concat(a collate noaccent, a) from tbl order by all;
----
öö
oo
pp
query I
select lower(a collate noaccent) from tbl order by all;
----
ö
o
p
query I
select upper(a collate noaccent) from tbl order by all;
----
Ö
O
P
query I
select trim(b collate noaccent, '<>') from tbl order by all
----
ö
o
p
query I
select ltrim(b collate noaccent, '<>') from tbl order by all
----
ö<<<<<
o<<<<<
p<<<<<
query I
select rtrim(b collate noaccent, '<>') from tbl order by all
----
>>>>>ö
>>>>>o
>>>>>p
query I
select repeat(a collate noaccent, 10) from tbl order by all;
----
öööööööööö
oooooooooo
pppppppppp
query I
select left(b collate noaccent, 6) from tbl order by all;
----
>>>>>ö
>>>>>o
>>>>>p
query I
select right(b collate noaccent, 6) from tbl order by all;
----
ö<<<<<
o<<<<<
p<<<<<
query I
select right(left(b collate noaccent, 6), 1) from tbl order by all;
----
ö
o
p
query I
select reverse(a collate noaccent) from tbl order by all;
----
ö
o
p
# test pushing collations
query I
select a from tbl where contains(b collate noaccent, 'o') order by all
----
o
ö
query I
select a from tbl where contains(b, 'ö' collate noaccent) order by all
----
o
ö
query I
select a from tbl where contains(b collate nocase, 'O') order by all
----
o
query I
select a from tbl where starts_with(b collate noaccent, '>>>>>o') order by all
----
o
ö
|