diff options
author | Amit Langote <amitlan@postgresql.org> | 2024-09-06 12:51:26 +0900 |
---|---|---|
committer | Amit Langote <amitlan@postgresql.org> | 2024-09-06 12:52:39 +0900 |
commit | eef5195f300bb9cf2864d48761c0db2ad93842c1 (patch) | |
tree | 6f17baf38858a677aa512ccd18381a3e3ce817e9 /src/backend/executor/execExpr.c | |
parent | e4e27976a687dd641c1c8251fad3a90a08756df8 (diff) |
Revert recent SQL/JSON related commits
Reverts c88ce386c4d, 5067c230b8e, and e4e27976a68, because a few BF
animals didn't like one or all of them.
Diffstat (limited to 'src/backend/executor/execExpr.c')
-rw-r--r-- | src/backend/executor/execExpr.c | 30 |
1 files changed, 8 insertions, 22 deletions
diff --git a/src/backend/executor/execExpr.c b/src/backend/executor/execExpr.c index 3db700dabf1..9b52bab52fc 100644 --- a/src/backend/executor/execExpr.c +++ b/src/backend/executor/execExpr.c @@ -4236,8 +4236,6 @@ ExecInitJsonExpr(JsonExpr *jsexpr, ExprState *state, ErrorSaveContext *escontext = jsexpr->on_error->btype != JSON_BEHAVIOR_ERROR ? &jsestate->escontext : NULL; - bool returning_domain = - get_typtype(jsexpr->returning->typid) == TYPTYPE_DOMAIN; jsestate->jsexpr = jsexpr; @@ -4380,27 +4378,20 @@ ExecInitJsonExpr(JsonExpr *jsexpr, ExprState *state, ExprEvalPushStep(state, scratch); } + jsestate->jump_empty = jsestate->jump_error = -1; + /* * Step to check jsestate->error and return the ON ERROR expression if * there is one. This handles both the errors that occur during jsonpath * evaluation in EEOP_JSONEXPR_PATH and subsequent coercion evaluation. - * - * Speed up common cases by avoiding extra steps for a NULL-valued ON - * ERROR expression unless RETURNING a domain type, where constraints must - * be checked. ExecEvalJsonExprPath() already returns NULL on error, - * making additional steps unnecessary in typical scenarios. Note that the - * default ON ERROR behavior for JSON_VALUE() and JSON_QUERY() is to - * return NULL. */ - jsestate->jump_error = state->steps_len; if (jsexpr->on_error && - jsexpr->on_error->btype != JSON_BEHAVIOR_ERROR && - (!(IsA(jsexpr->on_error->expr, Const) && - ((Const *) jsexpr->on_error->expr)->constisnull) || - returning_domain)) + jsexpr->on_error->btype != JSON_BEHAVIOR_ERROR) { ErrorSaveContext *saved_escontext; + jsestate->jump_error = state->steps_len; + /* JUMP to end if false, that is, skip the ON ERROR expression. */ jumps_to_end = lappend_int(jumps_to_end, state->steps_len); scratch->opcode = EEOP_JUMP_IF_NOT_TRUE; @@ -4450,19 +4441,14 @@ ExecInitJsonExpr(JsonExpr *jsexpr, ExprState *state, /* * Step to check jsestate->empty and return the ON EMPTY expression if * there is one. - * - * See the comment above for details on the optimization for NULL-valued - * expressions. */ - jsestate->jump_empty = state->steps_len; if (jsexpr->on_empty != NULL && - jsexpr->on_empty->btype != JSON_BEHAVIOR_ERROR && - (!(IsA(jsexpr->on_empty->expr, Const) && - ((Const *) jsexpr->on_empty->expr)->constisnull) || - returning_domain)) + jsexpr->on_empty->btype != JSON_BEHAVIOR_ERROR) { ErrorSaveContext *saved_escontext; + jsestate->jump_empty = state->steps_len; + /* JUMP to end if false, that is, skip the ON EMPTY expression. */ jumps_to_end = lappend_int(jumps_to_end, state->steps_len); scratch->opcode = EEOP_JUMP_IF_NOT_TRUE; |