Re: Dynamic constraint names in ALTER TABLE - Mailing list pgsql-general

From Ondrej Ivanič
Subject Re: Dynamic constraint names in ALTER TABLE
Date
Msg-id CAM6mie+Q4btvshrHpARrhDnG0544jTonP11FYtyE4VRnQUaxsQ@mail.gmail.com
Whole thread Raw
In response to Re: Dynamic constraint names in ALTER TABLE  (patrick keshishian <pkeshish@gmail.com>)
Responses Re: Dynamic constraint names in ALTER TABLE  (patrick keshishian <pkeshish@gmail.com>)
List pgsql-general
Hi,

On 20 September 2011 13:09, patrick keshishian <pkeshish@gmail.com> wrote:
> e.g., ALTER TABLE sales DROP CONSTRAINT (SELECT conname FROM
> pg_constraint JOIN pg_class ON (conrelid=pg_class.oid) WHERE
> pg_class.relname='sales' AND conkey[1] = 1 AND contype='f') ;

You have to build query in different way:

psql ... -A -t -c "SELECT 'ALTER TABLE sales DROP CONSTRAINT ' ||
conname || ';' FROM pg_constraint JOIN pg_class ON
(conrelid=pg_class.oid) WHERE pg_class.relname='sales' AND conkey[1] =
1 AND contype='f'"

Finally, you can save it in to file or pipe it to another psql:
psql ... -A -t -c '....' | psql ...

--
Ondrej Ivanic
(ondrej.ivanic@gmail.com)

pgsql-general by date:

Previous
From: patrick keshishian
Date:
Subject: Re: Dynamic constraint names in ALTER TABLE
Next
From: Tom Lane
Date:
Subject: Re: Dynamic constraint names in ALTER TABLE