Re: DELETE using an outer join

Поиск
Список
Период
Сортировка
От Tom Lane
Тема Re: DELETE using an outer join
Дата
Msg-id 16160.1342792275@sss.pgh.pa.us
обсуждение исходный текст
Ответ на Re: DELETE using an outer join  (Sergey Konoplev <gray.ru@gmail.com>)
Ответы Re: DELETE using an outer join  (Sergey Konoplev <sergey.konoplev@postgresql-consulting.com>)
Список 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 по дате отправления:

Предыдущее
От: Sergey Konoplev
Дата:
Сообщение: Re: DELETE using an outer join
Следующее
От: Sergey Konoplev
Дата:
Сообщение: Re: DELETE using an outer join