aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorAlvaro Herrera <alvherre@alvh.no-ip.org>2017-10-12 17:23:47 +0200
committerAlvaro Herrera <alvherre@alvh.no-ip.org>2017-10-12 17:32:48 +0200
commita01a3d931e5a14d60eec75f7945d5e66ff9cc575 (patch)
tree84cb6c2ba715bdfefe859096f771040fc8280f09 /src
parent7cde649ab150412344ee50fc90f24d6fe891bcf0 (diff)
downloadpostgresql-a01a3d931e5a14d60eec75f7945d5e66ff9cc575.tar.gz
postgresql-a01a3d931e5a14d60eec75f7945d5e66ff9cc575.zip
Infer functional dependency past RelabelType
Vars hidden within a RelabelType would not be detected as compatible with some functional dependency. Repair by properly ignoring the RelabelType. Author: David Rowley Reviewed-by: Tomas Vondra Discussion: https://postgr.es/m/CAKJS1f-y-UEy=rsBXynBOgiW1fKMr_LVoYSGL9QOc36mLEC-ww@mail.gmail.com
Diffstat (limited to 'src')
-rw-r--r--src/backend/statistics/dependencies.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/src/backend/statistics/dependencies.c b/src/backend/statistics/dependencies.c
index 2e7c0ad6ba6..9756fb83c0c 100644
--- a/src/backend/statistics/dependencies.c
+++ b/src/backend/statistics/dependencies.c
@@ -792,6 +792,14 @@ dependency_is_compatible_clause(Node *clause, Index relid, AttrNumber *attnum)
var = (varonleft) ? linitial(expr->args) : lsecond(expr->args);
+ /*
+ * We may ignore any RelabelType node above the operand. (There won't
+ * be more than one, since eval_const_expressions() has been applied
+ * already.)
+ */
+ if (IsA(var, RelabelType))
+ var = (Var *) ((RelabelType *) var)->arg;
+
/* We only support plain Vars for now */
if (!IsA(var, Var))
return false;