forked from github/dataease
refactor(过滤组件): 过滤组件不返回空值
This commit is contained in:
parent
b326d967b5
commit
2f5639bf0a
@ -2,7 +2,10 @@ package io.dataease.dataset.manage;
|
|||||||
|
|
||||||
import io.dataease.api.chart.dto.ColumnPermissionItem;
|
import io.dataease.api.chart.dto.ColumnPermissionItem;
|
||||||
import io.dataease.api.chart.dto.DeSortField;
|
import io.dataease.api.chart.dto.DeSortField;
|
||||||
import io.dataease.api.dataset.dto.*;
|
import io.dataease.api.dataset.dto.BaseTreeNodeDTO;
|
||||||
|
import io.dataease.api.dataset.dto.EnumValueRequest;
|
||||||
|
import io.dataease.api.dataset.dto.PreviewSqlDTO;
|
||||||
|
import io.dataease.api.dataset.dto.SqlLogDTO;
|
||||||
import io.dataease.api.dataset.union.DatasetGroupInfoDTO;
|
import io.dataease.api.dataset.union.DatasetGroupInfoDTO;
|
||||||
import io.dataease.api.dataset.union.DatasetTableInfoDTO;
|
import io.dataease.api.dataset.union.DatasetTableInfoDTO;
|
||||||
import io.dataease.api.permissions.dataset.dto.DataSetRowPermissionsTreeDTO;
|
import io.dataease.api.permissions.dataset.dto.DataSetRowPermissionsTreeDTO;
|
||||||
@ -11,7 +14,10 @@ import io.dataease.chart.manage.ChartViewManege;
|
|||||||
import io.dataease.chart.utils.ChartDataBuild;
|
import io.dataease.chart.utils.ChartDataBuild;
|
||||||
import io.dataease.commons.utils.SqlparserUtils;
|
import io.dataease.commons.utils.SqlparserUtils;
|
||||||
import io.dataease.dataset.constant.DatasetTableType;
|
import io.dataease.dataset.constant.DatasetTableType;
|
||||||
import io.dataease.dataset.utils.*;
|
import io.dataease.dataset.utils.DatasetUtils;
|
||||||
|
import io.dataease.dataset.utils.FieldUtils;
|
||||||
|
import io.dataease.dataset.utils.SqlUtils;
|
||||||
|
import io.dataease.dataset.utils.TableUtils;
|
||||||
import io.dataease.datasource.dao.auto.entity.CoreDatasource;
|
import io.dataease.datasource.dao.auto.entity.CoreDatasource;
|
||||||
import io.dataease.datasource.dao.auto.mapper.CoreDatasourceMapper;
|
import io.dataease.datasource.dao.auto.mapper.CoreDatasourceMapper;
|
||||||
import io.dataease.datasource.manage.EngineManage;
|
import io.dataease.datasource.manage.EngineManage;
|
||||||
@ -486,6 +492,16 @@ public class DatasetDataManage {
|
|||||||
datasourceRequest.setDsList(dsMap);
|
datasourceRequest.setDsList(dsMap);
|
||||||
Map<String, Object> data = calciteProvider.fetchResultField(datasourceRequest);
|
Map<String, Object> data = calciteProvider.fetchResultField(datasourceRequest);
|
||||||
List<String[]> dataList = (List<String[]>) data.get("data");
|
List<String[]> dataList = (List<String[]>) data.get("data");
|
||||||
|
dataList = dataList.stream().filter(row -> {
|
||||||
|
boolean hasEmpty = false;
|
||||||
|
for (String s : row) {
|
||||||
|
if (StringUtils.isBlank(s)) {
|
||||||
|
hasEmpty = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return !hasEmpty;
|
||||||
|
}).toList();
|
||||||
List<String> previewData = new ArrayList<>();
|
List<String> previewData = new ArrayList<>();
|
||||||
if (ObjectUtils.isNotEmpty(dataList)) {
|
if (ObjectUtils.isNotEmpty(dataList)) {
|
||||||
List<String> tmpData = dataList.stream().map(ele -> (ObjectUtils.isNotEmpty(ele) && ele.length > 0) ? ele[0] : null).collect(Collectors.toList());
|
List<String> tmpData = dataList.stream().map(ele -> (ObjectUtils.isNotEmpty(ele) && ele.length > 0) ? ele[0] : null).collect(Collectors.toList());
|
||||||
@ -701,6 +717,16 @@ public class DatasetDataManage {
|
|||||||
datasourceRequest.setDsList(dsMap);
|
datasourceRequest.setDsList(dsMap);
|
||||||
Map<String, Object> data = calciteProvider.fetchResultField(datasourceRequest);
|
Map<String, Object> data = calciteProvider.fetchResultField(datasourceRequest);
|
||||||
List<String[]> dataList = (List<String[]>) data.get("data");
|
List<String[]> dataList = (List<String[]>) data.get("data");
|
||||||
|
dataList = dataList.stream().filter(row -> {
|
||||||
|
boolean hasEmpty = false;
|
||||||
|
for (String s : row) {
|
||||||
|
if (StringUtils.isBlank(s)) {
|
||||||
|
hasEmpty = true;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return !hasEmpty;
|
||||||
|
}).toList();
|
||||||
Map<String, String[]> distinctData = new LinkedHashMap<>();
|
Map<String, String[]> distinctData = new LinkedHashMap<>();
|
||||||
for (String[] arr : dataList) {
|
for (String[] arr : dataList) {
|
||||||
String key = Arrays.toString(arr);
|
String key = Arrays.toString(arr);
|
||||||
@ -812,13 +838,14 @@ public class DatasetDataManage {
|
|||||||
// 重新构造data
|
// 重新构造data
|
||||||
Set<String> pkSet = new HashSet<>();
|
Set<String> pkSet = new HashSet<>();
|
||||||
rows = rows.stream().filter(row -> {
|
rows = rows.stream().filter(row -> {
|
||||||
boolean allEmpty = true;
|
boolean hasEmpty = false;
|
||||||
for (String s : row) {
|
for (String s : row) {
|
||||||
if (StringUtils.isNotBlank(s)) {
|
if (StringUtils.isBlank(s)) {
|
||||||
allEmpty = false;
|
hasEmpty = true;
|
||||||
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return !allEmpty;
|
return !hasEmpty;
|
||||||
}).toList();
|
}).toList();
|
||||||
List<BaseTreeNodeDTO> treeNodes = rows.stream().map(row -> buildTreeNode(row, pkSet)).flatMap(Collection::stream).collect(Collectors.toList());
|
List<BaseTreeNodeDTO> treeNodes = rows.stream().map(row -> buildTreeNode(row, pkSet)).flatMap(Collection::stream).collect(Collectors.toList());
|
||||||
List<BaseTreeNodeDTO> tree = DatasetUtils.mergeDuplicateTree(treeNodes, "root");
|
List<BaseTreeNodeDTO> tree = DatasetUtils.mergeDuplicateTree(treeNodes, "root");
|
||||||
|
Loading…
Reference in New Issue
Block a user