Re: Multi table insert

From: norman <norman_khine(at)yahoo(dot)co(dot)uk>
To: pgsql-novice(at)postgresql(dot)org
Subject: Re: Multi table insert
Date: 2006-10-27 13:49:30
Message-ID: 20061027134930.3409.qmail@web26515.mail.ukl.yahoo.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-novice

Hi and thanks for your replies.
The fix was as per Andreas' post and this works now.

Although, I would like to improve the code and make it better.

The ' business_name_business_name_seq' is just a sequence type for the table business_name where business_name table is related like:

business_name -> business_address by the business_name_id

as the submit form is just one form, i inserted the values in order so I needed the fk_business_name_id to be taken from the previous insert and so on...

perhaps there is better way to do this.

cheers

norman

George Pavlov <gpavlov(at)mynewplace(dot)com> wrote: can you replace:

business_name_business_name_seq.last_value

with:

(select last_value from business_name_business_name_seq)

or, more defensively coded:

(select max(last_value) from business_name_business_name_seq)

i am assuming business_name_business_name_seq is some kind of one-row
table that is always guaranteed (how?) to have one row and sort of fakes
a sequence (which brings the question of why not use a true sequence?)

> -----Original Message-----
> From: pgsql-novice-owner(at)postgresql(dot)org
> [mailto:pgsql-novice-owner(at)postgresql(dot)org] On Behalf Of norman
> Sent: Friday, October 27, 2006 5:08 AM
> To: pgsql-novice(at)postgresql(dot)org
> Subject: [NOVICE] Multi table insert
>
> Hello,
> I have created a multi-table insert script in python, the
> problem is that this worked fine on an older PostgreSQL db
> (7.2) but now I get an
>
> Error, psycopg2.ProgrammingError: missing FROM-clause entry
> for table "business_name_business_name_seq"
>
> Here is part of the script
>
> It is a Z SQL Method for Zope.
>
> ##########
>
>
> INSERT INTO business_name (business_name, business_url,
> business_type_id)
> values (
,
>
,

> business_type_list_id type="int">);
>
>

>
> INSERT INTO business_address (street_name, town, city,
> postcode, county_id, business_name_id) values
> (
,
>
,
>
,
>
,
>
,
> business_name_business_name_seq.last_value);
>
> #########
>
> Here I want to take the last_value for the business_name_id
> that was generated in the first insert and put it as the
> related item in the next INSERT table.
>
> Is there a better way to do this? I have 4 tables all related
> and one input form.
>
> Many thanks
>
> Norman
>

---------------------------(end of broadcast)---------------------------
TIP 4: Have you searched our list archives?

http://archives.postgresql.org

Send instant messages to your online friends http://uk.messenger.yahoo.com

In response to

Browse pgsql-novice by date

  From Date Subject
Next Message Greg Quinn 2006-10-27 16:38:24 Create Database Question
Previous Message George Pavlov 2006-10-27 13:33:22 Re: Multi table insert