| От | 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 по дате отправления:
Сайт использует файлы cookie для корректной работы и повышения удобства. Нажимая кнопку «Принять» или продолжая пользоваться сайтом, вы соглашаетесь на их использование в соответствии с Политикой в отношении обработки cookie ООО «ППГ», в том числе на передачу данных из файлов cookie сторонним статистическим и рекламным службам. Вы можете управлять настройками cookie через параметры вашего браузера