Re: Why is there no ADD CONSTRAINT IF NOT EXISTS ?

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: Why is there no ADD CONSTRAINT IF NOT EXISTS ?
Дата
Msg-id 757478.1619014080@sss.pgh.pa.us
обсуждение исходный текст
Ответ на Why is there no ADD CONSTRAINT IF NOT EXISTS ?  (Stephen Carboni <stephen.entropy@gmail.com>)
Список pgsql-novice
Stephen Carboni <stephen.entropy@gmail.com> writes:
> I can drop a constraint if it exists, but cannot simply add one if it does
> not exist. Is there something especially difficult about supporting this?

Probably some combination of (1) nobody got around to it yet and
(2) it's not entirely clear what the semantics ought to be.
Should we match on name, or contents of the constraint, and how
picky would a content match be?

There's a general problem with CREATE IF NOT EXISTS that you don't
really have any guarantee afterwards as to what are the details
of the object's definition.  Personally I prefer CREATE OR REPLACE
semantics, where you do know what the object looks like afterwards.
However, C.O.R. doesn't work that well unless there's a very clear
unique identity (e.g. name) for the object.  Since constraints are
often made without specifying a name, it's hard to be sure what
you're supposed to replace.  I'm not sure whether C.I.N.E. would
have as bad of a problem with that, but it seems possible.

            regards, tom lane



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

Предыдущее
От: Stephen Carboni
Дата:
Сообщение: Why is there no ADD CONSTRAINT IF NOT EXISTS ?
Следующее
От: Pavel Tide
Дата:
Сообщение: suppress empty archive_command warning message