Re: domain over enum problem

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: domain over enum problem
Дата
Msg-id 2971.1294769104@sss.pgh.pa.us
обсуждение исходный текст
Ответ на domain over enum problem  (Peter Eisentraut <peter_e@gmx.net>)
Список pgsql-bugs
Peter Eisentraut <peter_e@gmx.net> writes:
> CREATE TYPE zzz_enum AS ENUM ('A', 'B', 'C');
> CREATE TABLE zzz_test1 (z zzz_enum);
> SELECT * FROM zzz_test1 WHERE z = 'A';

> That works.  But:

> CREATE DOMAIN zzz AS zzz_enum DEFAULT 'A';
> CREATE TABLE zzz_test2 (z zzz);
> SELECT * FROM zzz_test2 WHERE z = 'A';
> ERROR:  42883: operator does not exist: zzz = unknown

I suppose this is because enforce_generic_type_consistency doesn't smash
domains to base types before checking type_is_enum.  I'm a bit hesitant
to change that though.  We don't smash to base types before checking if
a domain matches an anyarray, and I seem to recall that that's
intentional.

            regards, tom lane

В списке pgsql-bugs по дате отправления:

Предыдущее
От: Peter Eisentraut
Дата:
Сообщение: domain over enum problem
Следующее
От: Pavel Stehule
Дата:
Сообщение: Re: BUG #5831: Splitting string into char array with string_to_array does not work