Re: PL/SQL Function: self-contained transaction?

Поиск
Список
Период
Сортировка
От Greg Stark
Тема Re: PL/SQL Function: self-contained transaction?
Дата
Msg-id 8764txj0kv.fsf@stark.xeocode.com
обсуждение исходный текст
Ответ на PL/SQL Function: self-contained transaction?  ("Marc G. Fournier" <scrappy@postgresql.org>)
Ответы Re: PL/SQL Function: self-contained transaction?  (Richard_D_Levine@raytheon.com)
Список pgsql-sql
"Marc G. Fournier" <scrappy@postgresql.org> writes:

> In PostgreSQL, as everyone knows, a QUERY == a transaction, unless wrap'd in a
> BEGIN/END explicitly ... how does that work with a function?  is there an
> implicit BEGIN/END around the whole transaction, or each QUERY within the
> function itself?

The whole outer query issued from your frontend is in one transaction.

> If the whole function (and all QUERYs inside of it) are considered one
> transaction, can you do a begin/end within the function itself to 'force'
> commit on a specific part of the function?

Functions cannot issue start or end transactions. They're a creature of the
transaction you're in when you call them. Otherwise it wouldn't make sense to
be able to call them from within a query.

There is some discussion of "stored procedures" which would live outside of
transactions and be able to create transactions, commit, and roll them back.
But I don't think any of that work is committed yet. I'm not even sure it's
been written yet.

-- 
greg



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

Предыдущее
От: "Marc G. Fournier"
Дата:
Сообщение: PL/SQL Function: self-contained transaction?
Следующее
От: "A. Kretschmer"
Дата:
Сообщение: Re: PL/SQL Function: self-contained transaction?