From b2d03a0f51de2d9b25639d0e6e0f8c55f9e45487 Mon Sep 17 00:00:00 2001 From: Dmitry Yemanov Date: Fri, 10 Jan 2025 11:19:54 +0300 Subject: [PATCH] More correct plan output for subqueries generated during NOT IN transformation --- src/dsql/BoolNodes.cpp | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/src/dsql/BoolNodes.cpp b/src/dsql/BoolNodes.cpp index 38975713c5..b677ae5e11 100644 --- a/src/dsql/BoolNodes.cpp +++ b/src/dsql/BoolNodes.cpp @@ -2176,16 +2176,20 @@ BoolExprNode* RseBoolNode::convertNeqAllToNotAny(thread_db* tdbb, CompilerScratc andNode->arg1 = missNode; + RseNode* newInnerRse1 = innerRse->clone(csb->csb_pool); + newInnerRse1->flags |= RseNode::FLAG_SUB_QUERY; + RseBoolNode* rseBoolNode = FB_NEW_POOL(csb->csb_pool) RseBoolNode(csb->csb_pool, blr_any); - rseBoolNode->rse = innerRse; + rseBoolNode->rse = newInnerRse1; rseBoolNode->ownSavepoint = this->ownSavepoint; andNode->arg2 = rseBoolNode; - RseNode* newInnerRse = innerRse->clone(csb->csb_pool); + RseNode* newInnerRse2 = innerRse->clone(csb->csb_pool); + newInnerRse2->flags |= RseNode::FLAG_SUB_QUERY; rseBoolNode = FB_NEW_POOL(csb->csb_pool) RseBoolNode(csb->csb_pool, blr_any); - rseBoolNode->rse = newInnerRse; + rseBoolNode->rse = newInnerRse2; rseBoolNode->ownSavepoint = this->ownSavepoint; orNode->arg2 = rseBoolNode; @@ -2201,16 +2205,16 @@ BoolExprNode* RseBoolNode::convertNeqAllToNotAny(thread_db* tdbb, CompilerScratc outerRseNeq->blrOp = blr_eql; // If there was a boolean on the stream, append (AND) the new one - if (newInnerRse->rse_boolean) + if (newInnerRse2->rse_boolean) { andNode = FB_NEW_POOL(csb->csb_pool) BinaryBoolNode(csb->csb_pool, blr_and); - andNode->arg1 = newInnerRse->rse_boolean; + andNode->arg1 = newInnerRse2->rse_boolean; andNode->arg2 = boolean; boolean = andNode; } - newInnerRse->rse_boolean = boolean; + newInnerRse2->rse_boolean = boolean; SubExprNodeCopier copier(csb->csb_pool, csb); return copier.copy(tdbb, static_cast(newNode));