Commit e9ef11ac authored by Alvaro Herrera's avatar Alvaro Herrera

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
parent 360fd1a7
...@@ -792,6 +792,14 @@ dependency_is_compatible_clause(Node *clause, Index relid, AttrNumber *attnum) ...@@ -792,6 +792,14 @@ dependency_is_compatible_clause(Node *clause, Index relid, AttrNumber *attnum)
var = (varonleft) ? linitial(expr->args) : lsecond(expr->args); 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 */ /* We only support plain Vars for now */
if (!IsA(var, Var)) if (!IsA(var, Var))
return false; return false;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment