aboutsummaryrefslogtreecommitdiff
path: root/src/backend/nodes/outfuncs.c
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2011-10-23 00:43:39 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2011-10-23 00:43:39 -0400
commit0f39d5050dc0dce99258381f33f1832c437aff85 (patch)
tree90583250bd5cf7878686bad038ec74e9dd292744 /src/backend/nodes/outfuncs.c
parentbb446b689b6681eb57a8a50605e119743190c4db (diff)
downloadpostgresql-0f39d5050dc0dce99258381f33f1832c437aff85.tar.gz
postgresql-0f39d5050dc0dce99258381f33f1832c437aff85.zip
Don't trust deferred-unique indexes for join removal.
The uniqueness condition might fail to hold intra-transaction, and assuming it does can give incorrect query results. Per report from Marti Raudsepp, though this is not his proposed patch. Back-patch to 9.0, where both these features were introduced. In the released branches, add the new IndexOptInfo field to the end of the struct, to try to minimize ABI breakage for third-party code that may be examining that struct.
Diffstat (limited to 'src/backend/nodes/outfuncs.c')
-rw-r--r--src/backend/nodes/outfuncs.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/src/backend/nodes/outfuncs.c b/src/backend/nodes/outfuncs.c
index 98a02b27ddf..f7d39edf6fd 100644
--- a/src/backend/nodes/outfuncs.c
+++ b/src/backend/nodes/outfuncs.c
@@ -1770,6 +1770,7 @@ _outIndexOptInfo(StringInfo str, IndexOptInfo *node)
WRITE_NODE_FIELD(indextlist);
WRITE_BOOL_FIELD(predOK);
WRITE_BOOL_FIELD(unique);
+ WRITE_BOOL_FIELD(immediate);
WRITE_BOOL_FIELD(hypothetical);
}