From 7a25ca2e2d7888ae6727f9a227b1a5ac2f73d3ac Mon Sep 17 00:00:00 2001 From: junjun Date: Wed, 13 Mar 2024 15:04:58 +0800 Subject: [PATCH] =?UTF-8?q?feat:=20=E8=BF=87=E6=BB=A4=E7=BB=84=E4=BB=B6?= =?UTF-8?q?=E6=94=AF=E6=8C=81=E7=A9=BA=E6=95=B0=E6=8D=AE=E9=80=BB=E8=BE=91?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../dataease/engine/constant/SQLConstants.java | 2 ++ .../io/dataease/engine/trans/ExtWhere2Str.java | 16 +++++++++++++--- 2 files changed, 15 insertions(+), 3 deletions(-) diff --git a/core/core-backend/src/main/java/io/dataease/engine/constant/SQLConstants.java b/core/core-backend/src/main/java/io/dataease/engine/constant/SQLConstants.java index 130d0c2e3d..cf0eab9c81 100644 --- a/core/core-backend/src/main/java/io/dataease/engine/constant/SQLConstants.java +++ b/core/core-backend/src/main/java/io/dataease/engine/constant/SQLConstants.java @@ -100,4 +100,6 @@ public class SQLConstants { public static final String GROUP_CONCAT = "GROUP_CONCAT(%s)"; public static final String QUARTER = "QUARTER(%s)"; + + public static final String EMPTY_SIGN = "_empty_$"; } diff --git a/core/core-backend/src/main/java/io/dataease/engine/trans/ExtWhere2Str.java b/core/core-backend/src/main/java/io/dataease/engine/trans/ExtWhere2Str.java index 7382489ad2..f666739bcb 100644 --- a/core/core-backend/src/main/java/io/dataease/engine/trans/ExtWhere2Str.java +++ b/core/core-backend/src/main/java/io/dataease/engine/trans/ExtWhere2Str.java @@ -95,7 +95,12 @@ public class ExtWhere2Str { String whereValue = ""; if (StringUtils.containsIgnoreCase(request.getOperator(), "in")) { - whereValue = "('" + StringUtils.join(value, "','") + "')"; + // 过滤空数据 + if (value.contains(SQLConstants.EMPTY_SIGN)) { + whereValue = "('" + StringUtils.join(value, "','") + "', '')" + " or " + whereName + " is null "; + } else { + whereValue = "('" + StringUtils.join(value, "','") + "')"; + } } else if (StringUtils.containsIgnoreCase(request.getOperator(), "like")) { whereValue = "'%" + value.get(0) + "%'"; } else if (StringUtils.containsIgnoreCase(request.getOperator(), "between")) { @@ -112,7 +117,12 @@ public class ExtWhere2Str { whereValue = String.format(SQLConstants.WHERE_BETWEEN, value.get(0), value.get(1)); } } else { - whereValue = String.format(SQLConstants.WHERE_VALUE_VALUE, value.get(0)); + // 过滤空数据 + if (StringUtils.equals(value.get(0), SQLConstants.EMPTY_SIGN)) { + whereValue = String.format(SQLConstants.WHERE_VALUE_VALUE, "") + " or " + whereName + " is null "; + } else { + whereValue = String.format(SQLConstants.WHERE_VALUE_VALUE, value.get(0)); + } } list.add(SQLObj.builder() .whereField(whereName) @@ -120,7 +130,7 @@ public class ExtWhere2Str { .build()); } List strList = new ArrayList<>(); - list.forEach(ele -> strList.add(ele.getWhereField() + " " + ele.getWhereTermAndValue())); + list.forEach(ele -> strList.add("(" + ele.getWhereField() + " " + ele.getWhereTermAndValue() + ")")); meta.setExtWheres(ObjectUtils.isNotEmpty(list) ? "(" + String.join(" AND ", strList) + ")" : null); } }