Re: DELETE using an outer join - Mailing list pgsql-sql

From Tom Lane
Subject Re: DELETE using an outer join
Date
Msg-id 16160.1342792275@sss.pgh.pa.us
Whole thread Raw
In response to Re: DELETE using an outer join  (Sergey Konoplev <gray.ru@gmail.com>)
Responses Re: DELETE using an outer join  (Sergey Konoplev <sergey.konoplev@postgresql-consulting.com>)
List pgsql-sql
Sergey Konoplev <gray.ru@gmail.com> writes:
> On Thu, Jul 19, 2012 at 6:52 PM, Tom Lane <tgl@sss.pgh.pa.us> wrote:
>>> Now I was wondering if a DELETE statement could be rewritten with the same "strategy":

>> Not at the moment.  There have been discussions of allowing the same
>> table name to be respecified in USING, but there are complications.

> However it works.

> DELETE FROM some_table USING some_table AS s
> WHERE
>     some_table.col1 = s.col1 AND
>     some_table.col2 = s.col2 AND
>     some_table.id < s.id;

No, that's a self-join, which isn't what the OP wanted.  You can make it
work if you self-join on the primary key and then left join to the other
table, but that's pretty klugy and inefficient.

What was being discussed is allowing people to write directly

DELETE FROM some_table USING some_table LEFT JOIN other_table ...

where the respecification of the table in USING would be understood
to mean the target table.  Right now this is an error case because
of duplicate table aliases.
        regards, tom lane


pgsql-sql by date:

Previous
From: Sergey Konoplev
Date:
Subject: Re: DELETE using an outer join
Next
From: Sergey Konoplev
Date:
Subject: Re: DELETE using an outer join