diff options
author | Robert Haas <rhaas@postgresql.org> | 2011-10-28 12:02:04 -0400 |
---|---|---|
committer | Robert Haas <rhaas@postgresql.org> | 2011-10-28 12:03:05 -0400 |
commit | af0cc0f42ddb79c842d3410f31b32de9477b71e3 (patch) | |
tree | ec801bcb00d668c94320fe9c5cdd82e789128a6a | |
parent | e489c000d90d96b415f3309c0ba423a1584503bf (diff) | |
download | postgresql-af0cc0f42ddb79c842d3410f31b32de9477b71e3.tar.gz postgresql-af0cc0f42ddb79c842d3410f31b32de9477b71e3.zip |
Clarify that ORDER BY/FOR UPDATE can't malfunction at higher iso levels.
Kevin Grittner
-rw-r--r-- | doc/src/sgml/ref/select.sgml | 10 |
1 files changed, 9 insertions, 1 deletions
diff --git a/doc/src/sgml/ref/select.sgml b/doc/src/sgml/ref/select.sgml index 7fb52833e8a..f890ab2c835 100644 --- a/doc/src/sgml/ref/select.sgml +++ b/doc/src/sgml/ref/select.sgml @@ -1280,7 +1280,8 @@ ROLLBACK TO s; <caution> <para> - It is possible for a <command>SELECT</> command using <literal>ORDER + It is possible for a <command>SELECT</> command running at the <literal>READ + COMMITTED</literal> transaction isolation level and using <literal>ORDER BY</literal> and <literal>FOR UPDATE/SHARE</literal> to return rows out of order. This is because <literal>ORDER BY</> is applied first. The command sorts the result, but might then block trying to obtain a lock @@ -1301,6 +1302,13 @@ SELECT * FROM (SELECT * FROM mytable FOR UPDATE) ss ORDER BY column1; only if concurrent updates of the ordering columns are expected and a strictly sorted result is required. </para> + + <para> + At the <literal>REPEATABLE READ</literal> or <literal>SERIALIZABLE</literal> + transaction isolation level this would cause a serialization failure (with + a <literal>SQLSTATE</literal> of <literal>'40001'</literal>), so there is + no possibility of receiving rows out of order under these isolation levels. + </para> </caution> </refsect2> |