BUG #9820: Parentheses removed in chech constraint

Поиск
Список
Период
Сортировка
От ilussier@accovia.com
Тема BUG #9820: Parentheses removed in chech constraint
Дата
Msg-id 20140401150157.363.83570@wrigleys.postgresql.org
обсуждение исходный текст
Ответы Re: BUG #9820: Parentheses removed in chech constraint  (Tom Lane <tgl@sss.pgh.pa.us>)
Список pgsql-bugs
The following bug has been logged on the website:

Bug reference:      9820
Logged by:          Isabelle Lussier
Email address:      ilussier@accovia.com
PostgreSQL version: 9.3.2
Operating system:   Windows  (PgAdmin)
Description:

Hi, I'am want to add a check constraint that checks if the first condition
is true OR the second condition is true.  If one of the two conditions is
true, then the check is true.

Example:
alter table table_name add constraint c1 CHECK ( (type = 0 AND field1 IS NOT
NULL AND field2 IS NOT NULL AND field3 IS NOT NULL) OR (type_id = 1 AND
field1 IS NULL AND field2 IS NULL AND field3 IS NULL) )

At the execution of the query, the parentheses that defines condition 1 and
condition 2 are removed.  By removing the parentheses, the expression does
not means the same thing. Why postgresql removes the parentheses or how can
I do the constraint differently?

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

Предыдущее
От: Mike Blackwell
Дата:
Сообщение: Re: BUG #9518: temporary login failure - "missing pg_hba entry"
Следующее
От: Tom Lane
Дата:
Сообщение: Re: BUG #9820: Parentheses removed in chech constraint