zhuqi-lucas commented on code in PR #14245:
URL: https://github.com/apache/datafusion/pull/14245#discussion_r1934090147


##########
datafusion/physical-optimizer/src/limit_pushdown.rs:
##########
@@ -248,7 +247,15 @@ pub fn pushdown_limit_helper(
             }
         } else {
             // Add fetch or a `LimitExec`:
-            global_state.satisfied = true;
+            // If the plan's children have limit and the child's limit < 
parent's limit, we shouldn't change the global state to true,
+            // because the children limit will be overridden if the global 
state is changed.
+            if pushdown_plan
+                .children()
+                .iter()
+                .any(|&child| extract_limit(child).is_some())
+            {
+                global_state.satisfied = false;
+            }

Review Comment:
   Got it @xudong963 , the previous logic will always setting true in the 
global_state.satisfied == false. This logic is keep the false for some cases. I 
change the logic to more clear that, we only setting to true to exclude the 
above case.
   Thanks!
   
   



-- 
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.

To unsubscribe, e-mail: github-unsubscr...@datafusion.apache.org

For queries about this service, please contact Infrastructure at:
us...@infra.apache.org


---------------------------------------------------------------------
To unsubscribe, e-mail: github-unsubscr...@datafusion.apache.org
For additional commands, e-mail: github-h...@datafusion.apache.org

Reply via email to