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