Re: unique constraint definition within create table

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: unique constraint definition within create table
Дата
Msg-id 14838.1449067569@sss.pgh.pa.us
обсуждение исходный текст
Ответ на unique constraint definition within create table  (Andreas Kretschmer <akretschmer@spamfence.net>)
Список pgsql-sql
Andreas Kretschmer <akretschmer@spamfence.net> writes:
> i'm trying to create a table with 2 int-columns and a constraint that a
> pair of (x,y) cannot be as (y,x) inserted:

> test=# create table foo(u1 int,u2 int, unique (least(u1,u2),greatest(u1,u2)));
> ERROR:  syntax error at or near "("
> LINE 1: create table foo(u1 int,u2 int, unique (least(u1,u2),greates...

> I know, i can solve that in this way:

> test=*# create table foo(u1 int,u2 int);
> CREATE TABLE
> test=*# create unique index idx_foo on foo(least(u1,u2),greatest(u1,u2));
> CREATE INDEX

> But is there a way to define the unique constraint within the create table - command?

No.  Per SQL standard, the argument of a UNIQUE (or PRIMARY KEY)
constraint can only be a list of column names.

We would consider relaxing that, except it would break the
information_schema views for such constraints.
        regards, tom lane



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

Предыдущее
От: Andreas Kretschmer
Дата:
Сообщение: unique constraint definition within create table
Следующее
От: Adrian Klaver
Дата:
Сообщение: Re: unique constraint definition within create table