Re: [pgsql-ru-general] Re: [pgsql-ru-general] Возможно ли вставлять в несколько таблиц?

Поиск
Список
Период
Сортировка
От Dmitriy Igrishin
Тема Re: [pgsql-ru-general] Re: [pgsql-ru-general] Возможно ли вставлять в несколько таблиц?
Дата
Msg-id CAAfz9KMJsMKuYENmro9JWNPvH364=z6t-ePQ2eeeJtsk1-_fag@mail.gmail.com
обсуждение исходный текст
Ответ на Re: [pgsql-ru-general] Re: [pgsql-ru-general] Возможно ли вставлять в несколько таблиц?  (Sergey Konoplev <gray.ru@gmail.com>)
Список pgsql-ru-general


31 октября 2011 г. 13:11 пользователь Sergey Konoplev <gray.ru@gmail.com> написал:
2011/10/31 Dmitriy Igrishin <dmitigr@gmail.com>:
>> Поскольку INSERT - SELECT работает то возникает соблазн написать
>> INSERT INTO table2 (table1_id, name)
>>    INSERT INTO table1 (a, b) VALUES (1, 2) RETURNING "id", '123' AS "name"
>>
>> Но такая запись не работает. Говорит что синтаксическая ошибка на
>
> RETURNING ... не тоже самое, что SELECT ..., поэтому так
> делать нельзя. Добиться желаемого эффекта можно
> поместив INSERT ... RETURNING в функцию, возвращающую
> требуемый набор столбцов (или композитный тип).

Если 9.1, то для этого ещё можно использовать WITH с DML

http://www.postgresql.org/docs/9.1/static/queries-with.html#QUERIES-WITH-MODIFYING
Кстати да! Хорошая альтернатива!

--
// Dmitriy.


В списке pgsql-ru-general по дате отправления:

Предыдущее
От: Sergey Konoplev
Дата:
Сообщение: Re: [pgsql-ru-general] Re: [pgsql-ru-general] Возможно ли вставлять в несколько таблиц?
Следующее
От: Alexey Klyukin
Дата:
Сообщение: Re: [pgsql-ru-general] Возможно ли вставлять в несколько таблиц?