diff options
author | Peter Eisentraut <peter@eisentraut.org> | 2021-04-02 11:01:49 +0200 |
---|---|---|
committer | Peter Eisentraut <peter@eisentraut.org> | 2021-04-02 11:01:49 +0200 |
commit | 9c5f67fd6256246b2a788a8feb1d42b79dcd0448 (patch) | |
tree | 29341da82c83b885ee5f1a5b8a8632e7d61bc12a /src/backend | |
parent | 96bdb7e19de80a0c9521c5696455bca2a685c919 (diff) | |
download | postgresql-9c5f67fd6256246b2a788a8feb1d42b79dcd0448.tar.gz postgresql-9c5f67fd6256246b2a788a8feb1d42b79dcd0448.zip |
Add support for NullIfExpr in eval_const_expressions
Author: Hou Zhijie <houzj.fnst@cn.fujitsu.com>
Discussion: https://www.postgresql.org/message-id/flat/7ea5ce773bbc4eea9ff1a381acd3b102@G08CNEXMBPEKD05.g08.fujitsu.local
Diffstat (limited to 'src/backend')
-rw-r--r-- | src/backend/optimizer/util/clauses.c | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/src/backend/optimizer/util/clauses.c b/src/backend/optimizer/util/clauses.c index e89571ed40d..bea1cc4d67e 100644 --- a/src/backend/optimizer/util/clauses.c +++ b/src/backend/optimizer/util/clauses.c @@ -2497,6 +2497,36 @@ eval_const_expressions_mutator(Node *node, newexpr->location = expr->location; return (Node *) newexpr; } + case T_NullIfExpr: + { + NullIfExpr *expr; + ListCell *arg; + bool has_nonconst_input = false; + + /* Copy the node and const-simplify its arguments */ + expr = (NullIfExpr *) ece_generic_processing(node); + + /* If either argument is NULL they can't be equal */ + foreach(arg, expr->args) + { + if (!IsA(lfirst(arg), Const)) + has_nonconst_input = true; + else if (((Const *) lfirst(arg))->constisnull) + return (Node *) linitial(expr->args); + } + + /* + * Need to get OID of underlying function before checking if + * the function is OK to evaluate. + */ + set_opfuncid((OpExpr *) expr); + + if (!has_nonconst_input && + ece_function_is_safe(expr->opfuncid, context)) + return ece_evaluate_expr(expr); + + return (Node *) expr; + } case T_ScalarArrayOpExpr: { ScalarArrayOpExpr *saop; |