Re: [SQL] update by one transaction - Mailing list pgsql-sql

From Aleksey Dashevsky
Subject Re: [SQL] update by one transaction
Date
Msg-id Pine.LNX.3.96.SK.980611114949.20390A-100000@kesha.luckynet.co.il
Whole thread Raw
In response to update by one transaction  (Lendvary Gyorgy <gyurika@prolan.hu>)
List pgsql-sql

On Thu, 11 Jun 1998, Lendvary Gyorgy wrote:

> Hello,
>
> I have tried to write my problem, but I think nobody couldn,t understand
> it (because of my bad English, I think).
>
> I have a table for instance boci (row_number int, col2 float, col3
> float). The boci table has about 10000 rows.
> I want to update col3 column of the table in every row with different
> values. Desired values are in an array has 10000 elements. I want to be
> the value of the col3 column in the first row equal to the first element
> of the array and so on.
> I've done it with a 'for' cycle, but it is very slow. I want to do
> theese updates with one transaction.
>
> Here is a little piece of my program:
>
> for (i=0; i<10000; i++)
> {
>     sprintf(buff, "UPDATE boci SET col3 = %f WHERE row_number=%d",
> array[i], i);
>     PQexec(conn, buff);
> }
> PQexec(conn, "COMMIT");
>
> This program is very, very slow. Is there any way making this program
> much faster (for instance with CURSOR or 'block write' or something
> else)? Please write me a little program that describes your ideas!
>
> Thanks for your help in advance!
>
It seems you simply forgot to start transaction before the loop. So you
need to prepend this code with begin statement:

PQexec(conn, "BEGIN");

Hope, this will help!

Aleksey.


pgsql-sql by date:

Previous
From: Lendvary Gyorgy
Date:
Subject: update by one transaction
Next
From: "Jose' Soares Da Silva"
Date:
Subject: Re: [SQL] Order by birthdate