Re: Order of execution - Mailing list pgsql-sql

From Jasen Betts
Subject Re: Order of execution
Date
Msg-id km7rrp$qsh$1@gonzo.reversiblemaps.ath.cx
Whole thread Raw
In response to Order of execution  (JORGE MALDONADO <jorgemal1960@gmail.com>)
List pgsql-sql
On 2013-05-06, JORGE MALDONADO <jorgemal1960@gmail.com> wrote:
> --089e013d1eb83325e504dc01710d
> Content-Type: text/plain; charset=ISO-8859-1
>
> I have an UPDATE query which performs several opertions in one table.
>
> UPDATE table01 SET
> field1 = (query1 may contain any field),
> field2 = (query1 may contain any field),
> field3 = (query1 may contain any field)
> WHERE (condition)
>
> query1, query2 and query3 perform a logic to determine which records will
> be updated. Does field1 updates first, then  field2 and, lastly, field3?

Updates are one row at a time in an unpredictble order.
this will be wrapped in a transaction so either all will 
updated or none.

testing suggests that in simple cases the expressions are evaluated in
the order the columns appear in the table definition, but I wouldn't
rely on that.

> or What is the order in which updates are executed? If I need fields to be
> updated in a certain order, should I use 3 UPDATE commands instead?

yeah, if "simultaneously" isn't acceptable you'll need to do separate
updates.

-- 
⚂⚃ 100% natural




pgsql-sql by date:

Previous
From: JORGE MALDONADO
Date:
Subject: Order of execution
Next
From: Achilleas Mantzios
Date:
Subject: Re: Correct implementation of 1:n relationship with n>0?