Skip site navigation (1) Skip section navigation (2)

Peripheral Links

Header And Logo

PostgreSQL
| The world's most advanced open source database.

Site Navigation

Search archives
  Advanced Search

Re: sql-porting-problem oracle to postgresql with UPDATE/IS NOT NULL


  • From: Daryl Richter <ngzax(at)comcast(dot)net>
  • To: nha <lyondif02(at)free(dot)fr>
  • Cc: "Gau, Hans-Jürgen" <Hans-Juergen(dot)Gau(at)LGN(dot)Niedersachsen(dot)de>, PgSQL-sql <pgsql-sql(at)postgresql(dot)org>
  • Subject: Re: sql-porting-problem oracle to postgresql with UPDATE/IS NOT NULL
  • Date: Wed, 29 Jul 2009 09:44:37 -0400
  • Message-id: <BB25B038-BD93-44AA-94BC-6195913EECF7@comcast.net> <text/plain>

On Jul 28, 2009, at 5:10 PM, nha wrote:

Hello,

Le 28/07/09 14:25, Daryl Richter a écrit :

On Jul 28, 2009, at 5:58 AM, Gau, Hans-Jürgen wrote:

hello list,
i have some problems with an sql-statement which runs on oracle but
not on postgresql (i want update only if result of SELECT is not
empty, the SELECT-queries are identical):

UPDATE table1 t1
       SET (t1.id) =
               (SELECT h.id FROM table2 t2,table3 t3, table1 t1
               WHERE t3.field = t2.field
                       AND t2.id = t1.id
                       AND t1.id <> t3.id)
       WHERE
               (SELECT h.id FROM table2 t2,table3 t3, table1 t1
                       WHERE t3.field = t2.field
                               AND t2.id = t1.id
                               AND t1.id <> t3.id) IS NOT NULL;

Try this:

UPDATE table1 t1 [...]
       WHERE
           EXISTS (SELECT 1 FROM table2 t2,table3 t3, table1 t1
                       WHERE t3.field = t2.field
                               AND t2.id = t1.id
                               AND t1.id <> t3.id

               AND h.id IS NOT NULL);


Beyond the solution brought by Daryl Richter, it seems that "h" is an
unbound alias in the original (and also in the suggested) query. Some
clarification would be helpful for further investigation.

Ahh, you're right. I didn't even notice that, just reformatted the OPs query.


Regards.

--
nha / Lyon / France.

--
Sent via pgsql-sql mailing list (pgsql-sql(at)postgresql(dot)org)
To make changes to your subscription:
http://www.postgresql.org/mailpref/pgsql-sql

--
Daryl




Home | Main Index | Thread Index

Privacy Policy | About PostgreSQL
Copyright © 1996 – 2012 PostgreSQL Global Development Group