Обсуждение: BUG #2437: Rules for COPY

Поиск
Список
Период
Сортировка

BUG #2437: Rules for COPY

От
"Anton Fedorov"
Дата:
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.

Re: BUG #2437: Rules for COPY

От
Tom Lane
Дата:
"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

Re: BUG #2437: Rules for COPY

От
"Jim C. Nasby"
Дата:
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