How to cleanup transaction after statement_timeout aborts a query? - Mailing list pgsql-general

From Istvan Soos
Subject How to cleanup transaction after statement_timeout aborts a query?
Date
Msg-id CALdQGgv_an=JdfkomND7sJcuAS1L5OmbFzhQa9qcW48syTXyKg@mail.gmail.com
Whole thread Raw
Responses Re: How to cleanup transaction after statement_timeout aborts a query?
List pgsql-general
I'm one of the developers of the Dart-language Postgresql client
package. I am working on adding a feature that may set the
statement_timeout value before a session or a query as the client
requests it, however, I'm stuck with the following error:

setup:
CREATE TABLE t (id INT PRIMARY KEY);
INSERT INTO t (id) values (1);

client-1:
BEGIN;
SELECT * FROM t WHERE id=1 FOR UPDATE;
<client sleeps for a while>

client-2:
BEGIN;
SET statement_timeout TO 1000;
SELECT * FROM t WHERE id=1 FOR UPDATE;
<server sends error message with the timeout>

After that any query I send through client-2 will get me the following error:

Severity.error 25P02: current transaction is aborted, commands ignored
until end of transaction block

Not even ROLLBACK or COMMIT is working. It is the same for both simple
and extended query protocol. Does the client need to send a non-query
message to cleanup the transaction state? Or is this connection now
gone for good?

Thanks,
  Istvan



pgsql-general by date:

Previous
From: sud
Date:
Subject: How effectively do the indexing in postgres in such cases
Next
From: Laurenz Albe
Date:
Subject: Re: How to cleanup transaction after statement_timeout aborts a query?