Re: COPY FROM with a serial not null column

From: John Taylor <postgres(at)jtresponse(dot)co(dot)uk>
To: Oliver Elphick <olly(at)lfix(dot)co(dot)uk>
Cc: PgSQL Novice <pgsql-novice(at)postgresql(dot)org>
Subject: Re: COPY FROM with a serial not null column
Date: 2002-08-16 16:27:07
Message-ID: 02081617270706.01454@splash.hq.jtresponse.co.uk
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-novice

On Friday 16 August 2002 17:19, Oliver Elphick wrote:
> On Fri, 2002-08-16 at 16:20, John Taylor wrote:
> > Hi,
> >
> > I'm having trouble using COPY FROM with a table that has a serial NOT NULL column.
> >
> > If I use psql to INSERT with a NULL value for the appropriate column, everything
> > works fine, and the next value in the sequence is inserted.
> >
> > However, if I use COPY table FROM filename, I get an error:
> > ERROR: copy: line 1, CopyFrom: Fail to add null value in not null attribute seq
> >
> > (The column in question is called seq).
> >
> > Does anyone have ideas how I can get this to work ?
>
> You can't use sequences in conjunction with COPY; you have to fill in
> the field in your input text file.
>
> If it is a big file, you could use a tool such as awk or perl to write a
> value into each line of input. After loading the file, you will need to
> set the sequence value:
>
> SELECT setval('sequence_name', last_value);
>

OK,
I'll get the sequence value, and then create my copy file and insert the values manually.

Can I lock the sequence, to stop the numbers being re-used while I am creating and loading
the copyfile ?

Thanks
JohnT

In response to

Browse pgsql-novice by date

  From Date Subject
Next Message Chad Thompson 2002-08-16 16:52:53 Re: BLOBs
Previous Message Oliver Elphick 2002-08-16 16:19:11 Re: COPY FROM with a serial not null column