Re: dropping non-existent tables - Mailing list pgsql-general

From Walsh, Richard (Richard)
Subject Re: dropping non-existent tables
Date
Msg-id 73E4F3992055E8429385A496BCCC90EC1073F0A2@bg0007avexu1.global.avaya.com
Whole thread Raw
In response to dropping non-existent tables  ("Walsh, Richard (Richard)" <richardwalsh@avaya.com>)
List pgsql-general
Hi Michael,
I am executing these statements inside an SQL DDL script so I think they
all take place inside a single transaction. I am not using PSQL. I will
try what you suggest and see if executing the drop statements in a
separate tx will work.
Richie.

-----Original Message-----
From: Michael Fuhr [mailto:mike@fuhr.org]
Sent: 26 July 2005 23:09
To: Walsh, Richard (Richard)
Cc: pgsql-general@postgresql.org
Subject: Re: [GENERAL] dropping non-existent tables

On Tue, Jul 26, 2005 at 06:04:08PM +0200, Walsh, Richard (Richard)
wrote:
> I have a problem in that I need to drop non-existent tables in a DDL
> script. This is in order that the script can re-build a database
> schema if the tables already exist. However, in Postgres this is
> proving to be a problem because if the table does not exist then the
> DDL execution will stop once it gets an error.

Are you executing the statements inside a transaction?  If so then you
could execute the DROP statements in separate transactions (or execute
them outside of any transaction in autocommit mode).  Also, if you're
using psql then make sure you don't have ON_ERROR_STOP set.

In PostgreSQL 8.1, psql will have an ON_ERROR_ROLLBACK setting that uses
savepoints to automatically roll back failed statements while allowing
the rest of the transaction to continue.

--
Michael Fuhr
http://www.fuhr.org/~mfuhr/



pgsql-general by date:

Previous
From: "Walsh, Richard (Richard)"
Date:
Subject: Re: dropping non-existent tables
Next
From: Robert Treat
Date:
Subject: duplicate messages?