Re: Support LIKE with nondeterministic collations - Mailing list pgsql-hackers

From Daniel Verite
Subject Re: Support LIKE with nondeterministic collations
Date
Msg-id a827cf68-608e-45cf-9b94-e46f5e9d4171@manitou-mail.org
Whole thread Raw
In response to Support LIKE with nondeterministic collations  (Peter Eisentraut <peter@eisentraut.org>)
Responses Re: Support LIKE with nondeterministic collations
Re: Support LIKE with nondeterministic collations
List pgsql-hackers
    Peter Eisentraut wrote:

> This patch adds support for using LIKE with nondeterministic
>  collations.  So you can do things such as
>
>     col LIKE 'foo%' COLLATE case_insensitive

Nice!

> The pattern is partitioned into substrings at wildcard characters
> (so 'foo%bar' is partitioned into 'foo', '%', 'bar') and then then
> whole predicate matches if a match can be found for each partition
> under the applicable collation

Trying with a collation that ignores punctuation:

  postgres=# CREATE COLLATION "ign_punct" (
    provider = 'icu',
    locale='und-u-ka-shifted',
    deterministic = false
  );

  postgres=# SELECT '.foo.' like 'foo' COLLATE ign_punct;
   ?column?
  ----------
   t
  (1 row)

  postgres=# SELECT '.foo.' like 'f_o' COLLATE ign_punct;
   ?column?
  ----------
   t
  (1 row)

  postgres=# SELECT '.foo.' like '_oo' COLLATE ign_punct;
   ?column?
  ----------
   f
  (1 row)

The first two results look fine, but the next one is inconsistent.


Best regards,
--
Daniel Vérité
https://postgresql.verite.pro/
Twitter: @DanielVerite



pgsql-hackers by date:

Previous
From: Daniel Gustafsson
Date:
Subject: Re: BitmapHeapScan streaming read user and prelim refactoring
Next
From: Tom Lane
Date:
Subject: Re: pg_trgm comparison bug on cross-architecture replication due to different char implementation