Re: replacing mysql enum

Поиск
Список
Период
Сортировка
От Rod Taylor
Тема Re: replacing mysql enum
Дата
Msg-id 1102782901.26218.173.camel@home
обсуждение исходный текст
Ответ на Re: replacing mysql enum  (Stephan Szabo <sszabo@megazone.bigpanda.com>)
Ответы Re: replacing mysql enum
Список pgsql-sql
On Sat, 2004-12-11 at 07:47 -0800, Stephan Szabo wrote:
> On Sat, 11 Dec 2004, Ian Barwick wrote:
> 
> > (Oddly enough, putting the NULL in the CHECK constraint seems
> > to make the constraint worthless:
> > test=> create table consttest (field varchar(2)  check (field in
> > (null, 'a','b','c')));
> > CREATE TABLE
> > test=> insert into consttest values ('xx');
> > INSERT 408080 1
> > test=> SELECT * from consttest ;
> >  field
> > -------
> >  xx
> > (1 row)
> >
> > Not sure what logic is driving this).
> 
> The way NULL is handled in IN (because it's effectively an equality
> comparison). Unless I miss-remember the behavior, foo in (NULL, ...) can
> never return false and constraints are satisified unless the search
> condition returns false for some row.  I think this means you need the
> more verbose (field is null or field in ('a','b','c'))

Actually, he just needs check(field in ('a', 'b', 'c')).  NULL is
accepted unless explicitly denied (NOT NULL constraint or an IS NOT NULL
check).

-- 



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

Предыдущее
От: Stephan Szabo
Дата:
Сообщение: Re: replacing mysql enum
Следующее
От: Stephan Szabo
Дата:
Сообщение: Re: replacing mysql enum