summaryrefslogtreecommitdiff
path: root/src/backend/utils/adt/selfuncs.c
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2011-10-23 00:43:52 -0400
committerTom Lane <tgl@sss.pgh.pa.us>2011-10-23 00:43:52 -0400
commit9fbb3edff085f2f004c24b988b43c7cd4f132e2f (patch)
tree1a360a0fda28d51e64f6b8784f84d4a37fe3cd6f /src/backend/utils/adt/selfuncs.c
parent015cda44cfc5e02ec7147ab55560bd14c74acf08 (diff)
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/utils/adt/selfuncs.c')
-rw-r--r--src/backend/utils/adt/selfuncs.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/backend/utils/adt/selfuncs.c b/src/backend/utils/adt/selfuncs.c
index 7c1567a2cc3..6989627adc3 100644
--- a/src/backend/utils/adt/selfuncs.c
+++ b/src/backend/utils/adt/selfuncs.c
@@ -4102,7 +4102,9 @@ get_join_variables(PlannerInfo *root, List *args, SpecialJoinInfo *sjinfo,
* commonly the same as the exposed type of the variable argument,
* but can be different in binary-compatible-type cases.
* isunique: TRUE if we were able to match the var to a unique index,
- * implying its values are unique for this query.
+ * implying its values are unique for this query. (Caution: this
+ * should be trusted for statistical purposes only, since we do not
+ * check indimmediate.)
*
* Caller is responsible for doing ReleaseVariableStats() before exiting.
*/