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

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

commit 19dec4f5808e68f9a60a202e5542a276a781cd18
Author: amory <wangqian...@selectdb.com>
AuthorDate: Thu Aug 3 19:40:45 2023 +0800

    [FIX](array)fix if function for array() #22553
    
    [FIX](array)fix if function for array() #22553
---
 .../java/org/apache/doris/analysis/FunctionCallExpr.java    |  3 +++
 .../sql_functions/conditional_functions/test_if.out         | 13 +++++++++++++
 .../sql_functions/conditional_functions/test_if.groovy      |  6 +++++-
 3 files changed, 21 insertions(+), 1 deletion(-)

diff --git 
a/fe/fe-core/src/main/java/org/apache/doris/analysis/FunctionCallExpr.java 
b/fe/fe-core/src/main/java/org/apache/doris/analysis/FunctionCallExpr.java
index 7101401bb3..3f9211378f 100644
--- a/fe/fe-core/src/main/java/org/apache/doris/analysis/FunctionCallExpr.java
+++ b/fe/fe-core/src/main/java/org/apache/doris/analysis/FunctionCallExpr.java
@@ -1700,6 +1700,9 @@ public class FunctionCallExpr extends Expr {
                         && args[ix].isDecimalV3OrContainsDecimalV3())) {
                     // Do not do this cast if types are both decimalv3 with 
different precision/scale.
                     uncheckedCastChild(args[ix], i);
+                } else if (fnName.getFunction().equalsIgnoreCase("if")
+                        && argTypes[i].isArrayType() && ((ArrayType) 
argTypes[i]).getItemType().isNull()) {
+                    uncheckedCastChild(args[ix], i);
                 }
             }
         }
diff --git 
a/regression-test/data/query_p0/sql_functions/conditional_functions/test_if.out 
b/regression-test/data/query_p0/sql_functions/conditional_functions/test_if.out
new file mode 100644
index 0000000000..832f69157d
--- /dev/null
+++ 
b/regression-test/data/query_p0/sql_functions/conditional_functions/test_if.out
@@ -0,0 +1,13 @@
+-- This file is automatically generated. You should know what you did if you 
want to edit this
+-- !select --
+\N
+
+-- !select --
+["1970-01-01", "1970-01-01"]
+
+-- !select --
+["1970-01-01", "1970-01-01"]
+
+-- !select --
+[]
+
diff --git 
a/regression-test/suites/query_p0/sql_functions/conditional_functions/test_if.groovy
 
b/regression-test/suites/query_p0/sql_functions/conditional_functions/test_if.groovy
index c546e7891b..9a99e8bbd9 100644
--- 
a/regression-test/suites/query_p0/sql_functions/conditional_functions/test_if.groovy
+++ 
b/regression-test/suites/query_p0/sql_functions/conditional_functions/test_if.groovy
@@ -16,5 +16,9 @@
 // under the License.
 
 suite("test_if") {
-    sql "select if(id=1,count,hll_empty()) from (select 1 as id, hll_hash(1) 
as count) t"
+    qt_select "select if(id=1,count,hll_empty()) from (select 1 as id, 
hll_hash(1) as count) t"
+
+    qt_select "select if(job_d is null, array(), job_d) as test from (select 
array('1970-01-01', '1970-01-01') as job_d) t"
+    qt_select "select if(job_d is null, array('1970-01-01'), job_d) as test 
from (select array('1970-01-01', '1970-01-01') as job_d) t"
+    qt_select "select if(job_d is null, job_d, array()) as test from (select 
array('1970-01-01', '1970-01-01') as job_d) t"
 }


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

Reply via email to