Re: Asynchronous query execution

Поиск
Список
Период
Сортировка
От Merlin Moncure
Тема Re: Asynchronous query execution
Дата
Msg-id AANLkTikxoVadpC9WGEkBh=U=239mFgE4iGoHHxEQBWt-@mail.gmail.com
обсуждение исходный текст
Ответ на Re: Asynchronous query execution  (John R Pierce <pierce@hogranch.com>)
Ответы Re: Asynchronous query execution  (c k <shreeseva.learning@gmail.com>)
Список pgsql-general
On Wed, Dec 8, 2010 at 8:40 AM, John R Pierce <pierce@hogranch.com> wrote:
> On 12/08/10 5:35 AM, c k wrote:
>>
>> Hello,
>> I would like to know how can we execute the queries asynchronously?
>> If we use and execute plpgsql functions they just completes the execution
>> or throws an error on error. In between next sql statement waits for the
>> previous one to complete the execution. But in few situations it is required
>> not to wait for getting the completion of previous sql statement. How can
>> this e achieved?
>>
>
> one postgresql connection can only run one query at a time.
>
> run your asynchronous queries from a thread with its own connection

This is only asynchronous from client point of view.  Meaning, while
the query is running, you can go off and do other work on the client.

There is iron clad rule of one query running per database session at a
time.  From pl/pgsql point of view, only method of working around this
is using dblink style tricks to connect to the database from within
function and run queries.   dblink supports asynchronous querying so
you can leverage that:

dblink_send_query(text connname, text sql) returns int

From client point of view, you have a number of techniques.
async_queries/threads and multiple connections would be the most
common approaches.

merlin

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

Предыдущее
От: Vick Khera
Дата:
Сообщение: Re: SELECT is immediate but the UPDATE takes forever
Следующее
От: "Igor Neyman"
Дата:
Сообщение: Re: How to obtain the maximum value of a date, between 3 tables...