Thread: BUG #2437: Rules for COPY
The following bug has been logged online: Bug reference: 2437 Logged by: Anton Fedorov Email address: datacompboy@mail.ru PostgreSQL version: 8.1.3-3 Operating system: debian linux Description: Rules for COPY Details: Looks like COPY bypass rules 'ON INSERT INSTEAD'. I think, COPY .. FROM ... should be equal to INSERT INTO ... SELECT * FROM ... and be catched by INSERT rule. Otherwise, need to create new temporary table, load data into, INSERT .. SELECT ..., DROP TABLE, while it seems strange.
"Anton Fedorov" <datacompboy@mail.ru> writes: > Looks like COPY bypass rules 'ON INSERT INSTEAD'. That's the documented behavior. We're unlikely to change it because it'd slow COPY down substantially, which'd negate its main use of being a bulk data loading mechanism. regards, tom lane
On Mon, May 15, 2006 at 09:50:57AM -0400, Tom Lane wrote: > "Anton Fedorov" <datacompboy@mail.ru> writes: > > Looks like COPY bypass rules 'ON INSERT INSTEAD'. > > That's the documented behavior. We're unlikely to change it because > it'd slow COPY down substantially, which'd negate its main use of being > a bulk data loading mechanism. http://pgfoundry.org/projects/pgloader/ might allow for using inserts and therefore firing ON INSERT rules. Another option is to COPY into a temporary table, and then to INSERT INTO. The problem with COPY not firing ON INSERT is that COPY is the only convenient way to load data in that doesn't already happen to be formatted as INSERT statements, so it would be nice if there was an option that allowed you to have it follow normal INSERT conventions. Or perhaps if there was a utility that allowed reading from an on-disk file as if it was a table... I know Oracle has that ability, maybe EnterpriseDB has it as well... -- Jim C. Nasby, Sr. Engineering Consultant jnasby@pervasive.com Pervasive Software http://pervasive.com work: 512-231-6117 vcard: http://jim.nasby.net/pervasive.vcf cell: 512-569-9461