This is an automated email from the ASF dual-hosted git repository.

zhangstar333 pushed a commit to branch branch-3.0
in repository https://gitbox.apache.org/repos/asf/doris.git


The following commit(s) were added to refs/heads/branch-3.0 by this push:
     new 13ae167dcc5 branch-3.0: [enhance](nereids) remove first_value and 
second_value second parameter if the second parameter is false #45264 (#45453)
13ae167dcc5 is described below

commit 13ae167dcc58baa46f65b89191c08a5158b7aa09
Author: github-actions[bot] 
<41898282+github-actions[bot]@users.noreply.github.com>
AuthorDate: Mon Dec 16 18:23:43 2024 +0800

    branch-3.0: [enhance](nereids) remove first_value and second_value second 
parameter if the second parameter is false #45264 (#45453)
    
    Cherry-picked from #45264
    
    Co-authored-by: feiniaofeiafei <moail...@selectdb.com>
---
 .../rules/analysis/WindowFunctionChecker.java      | 14 ++++++++--
 .../CheckAndStandardizeWindowFunctionTest.java     | 26 ++++++++++++++++++
 .../data/nereids_syntax_p0/window_function.out     | 32 ++++++++++++++++++++++
 .../nereids_syntax_p0/window_function.groovy       |  3 ++
 4 files changed, 73 insertions(+), 2 deletions(-)

diff --git 
a/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/analysis/WindowFunctionChecker.java
 
b/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/analysis/WindowFunctionChecker.java
index d6904ae074c..2da28269fd7 100644
--- 
a/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/analysis/WindowFunctionChecker.java
+++ 
b/fe/fe-core/src/main/java/org/apache/doris/nereids/rules/analysis/WindowFunctionChecker.java
@@ -317,9 +317,15 @@ public class WindowFunctionChecker extends 
DefaultExpressionVisitor<Expression,
     @Override
     public FirstOrLastValue visitFirstValue(FirstValue firstValue, Void ctx) {
         FirstOrLastValue.checkSecondParameter(firstValue);
-        if (2 == firstValue.arity() && 
firstValue.child(1).equals(BooleanLiteral.TRUE)) {
-            return firstValue;
+        if (2 == firstValue.arity()) {
+            if (firstValue.child(1).equals(BooleanLiteral.TRUE)) {
+                return firstValue;
+            } else {
+                firstValue = (FirstValue) 
firstValue.withChildren(firstValue.child(0));
+                windowExpression = windowExpression.withFunction(firstValue);
+            }
         }
+
         Optional<WindowFrame> windowFrame = windowExpression.getWindowFrame();
         if (windowFrame.isPresent()) {
             WindowFrame wf = windowFrame.get();
@@ -347,6 +353,10 @@ public class WindowFunctionChecker extends 
DefaultExpressionVisitor<Expression,
     @Override
     public FirstOrLastValue visitLastValue(LastValue lastValue, Void ctx) {
         FirstOrLastValue.checkSecondParameter(lastValue);
+        if (2 == lastValue.arity() && 
lastValue.child(1).equals(BooleanLiteral.FALSE)) {
+            lastValue = (LastValue) lastValue.withChildren(lastValue.child(0));
+            windowExpression = windowExpression.withFunction(lastValue);
+        }
         return lastValue;
     }
 
diff --git 
a/fe/fe-core/src/test/java/org/apache/doris/nereids/rules/rewrite/CheckAndStandardizeWindowFunctionTest.java
 
b/fe/fe-core/src/test/java/org/apache/doris/nereids/rules/rewrite/CheckAndStandardizeWindowFunctionTest.java
index ffe88af2fea..2f3b133fdeb 100644
--- 
a/fe/fe-core/src/test/java/org/apache/doris/nereids/rules/rewrite/CheckAndStandardizeWindowFunctionTest.java
+++ 
b/fe/fe-core/src/test/java/org/apache/doris/nereids/rules/rewrite/CheckAndStandardizeWindowFunctionTest.java
@@ -28,11 +28,14 @@ import 
org.apache.doris.nereids.trees.expressions.WindowFrame;
 import org.apache.doris.nereids.trees.expressions.WindowFrame.FrameBoundary;
 import org.apache.doris.nereids.trees.expressions.WindowFrame.FrameUnitsType;
 import org.apache.doris.nereids.trees.expressions.functions.window.DenseRank;
+import org.apache.doris.nereids.trees.expressions.functions.window.FirstValue;
 import org.apache.doris.nereids.trees.expressions.functions.window.Lag;
+import org.apache.doris.nereids.trees.expressions.functions.window.LastValue;
 import org.apache.doris.nereids.trees.expressions.functions.window.Lead;
 import org.apache.doris.nereids.trees.expressions.functions.window.Rank;
 import org.apache.doris.nereids.trees.expressions.functions.window.RowNumber;
 import 
org.apache.doris.nereids.trees.expressions.functions.window.WindowFunction;
+import org.apache.doris.nereids.trees.expressions.literal.BooleanLiteral;
 import org.apache.doris.nereids.trees.expressions.literal.DoubleLiteral;
 import org.apache.doris.nereids.trees.expressions.literal.IntegerLiteral;
 import org.apache.doris.nereids.trees.plans.Plan;
@@ -240,6 +243,29 @@ public class CheckAndStandardizeWindowFunctionTest 
implements MemoPatternMatchSu
         forCheckWindowFrameBeforeFunc(windowFrame2, errorMsg2);
     }
 
+    @Test
+    public void testFirstValueRewrite() {
+        age = rStudent.getOutput().get(3).toSlot();
+        WindowExpression window = new WindowExpression(new FirstValue(age, 
BooleanLiteral.FALSE), partitionKeyList, orderKeyList);
+        Alias windowAlias = new Alias(window, window.toSql());
+        WindowExpression windowLastValue = new WindowExpression(new 
LastValue(age, BooleanLiteral.FALSE), partitionKeyList, orderKeyList);
+        Alias windowLastValueAlias = new Alias(windowLastValue, 
windowLastValue.toSql());
+        List<NamedExpression> outputExpressions = 
Lists.newArrayList(windowAlias, windowLastValueAlias);
+        Plan root = new LogicalWindow<>(outputExpressions, rStudent);
+
+        PlanChecker.from(MemoTestUtils.createConnectContext(), root)
+                .applyTopDown(new ExtractAndNormalizeWindowExpression())
+                .applyTopDown(new CheckAndStandardizeWindowFunctionAndFrame())
+                .matches(
+                        logicalWindow()
+                                .when(logicalWindow -> {
+                                    WindowExpression newWindowFirstValue = 
(WindowExpression) logicalWindow.getWindowExpressions().get(0).child(0);
+                                    WindowExpression newWindowLastValue = 
(WindowExpression) logicalWindow.getWindowExpressions().get(0).child(0);
+                                    return 
newWindowFirstValue.getFunction().arity() == 1 && 
newWindowLastValue.getFunction().arity() == 1;
+                                })
+                );
+    }
+
     private void forCheckWindowFrameBeforeFunc(WindowFrame windowFrame, String 
errorMsg) {
         WindowExpression window = new WindowExpression(new Rank(), 
partitionKeyList, orderKeyList, windowFrame);
         forCheckWindowFrameBeforeFunc(window, errorMsg);
diff --git a/regression-test/data/nereids_syntax_p0/window_function.out 
b/regression-test/data/nereids_syntax_p0/window_function.out
index 38eba68274e..378524125c9 100644
--- a/regression-test/data/nereids_syntax_p0/window_function.out
+++ b/regression-test/data/nereids_syntax_p0/window_function.out
@@ -567,3 +567,35 @@
 -- !multi_winf2 --
 1      35
 
+-- !first_value_false --
+1
+1
+1
+1
+1
+1
+1
+1
+2
+2
+2
+2
+2
+2
+
+-- !last_value_false --
+1
+1
+1
+1
+1
+1
+1
+1
+1
+1
+1
+1
+1
+1
+
diff --git a/regression-test/suites/nereids_syntax_p0/window_function.groovy 
b/regression-test/suites/nereids_syntax_p0/window_function.groovy
index f2ce708f4c3..bb19aba17c1 100644
--- a/regression-test/suites/nereids_syntax_p0/window_function.groovy
+++ b/regression-test/suites/nereids_syntax_p0/window_function.groovy
@@ -314,4 +314,7 @@ suite("window_function") {
     sql "select last_value(c1,false) over() from window_test"
     sql "select first_value(c1,1) over() from window_test"
     sql "select last_value(c1,0) over() from window_test"
+
+    qt_first_value_false "select last_value(c1,false) over(partition by c2 
order by c1) from window_test order by 1"
+    qt_last_value_false "select first_value(c1,false) over(partition by c2 
order by c1) from window_test order by 1"
 }


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

Reply via email to