forked from github/dataease
fix(仪表板): 修复过滤组件排序报错的问题
This commit is contained in:
parent
9e58760b43
commit
06ce7d6d1e
@ -674,6 +674,7 @@ public class DatasetDataManage {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// 排序
|
// 排序
|
||||||
|
boolean sortDistinct = true;
|
||||||
if (ObjectUtils.isNotEmpty(request.getSortId())) {
|
if (ObjectUtils.isNotEmpty(request.getSortId())) {
|
||||||
DatasetTableFieldDTO field = datasetTableFieldManage.selectById(request.getSortId());
|
DatasetTableFieldDTO field = datasetTableFieldManage.selectById(request.getSortId());
|
||||||
if (field == null) {
|
if (field == null) {
|
||||||
@ -683,13 +684,14 @@ public class DatasetDataManage {
|
|||||||
BeanUtils.copyBean(deSortField, field);
|
BeanUtils.copyBean(deSortField, field);
|
||||||
deSortField.setOrderDirection(request.getSort());
|
deSortField.setOrderDirection(request.getSort());
|
||||||
datasetGroupInfoDTO.setSortFields(Collections.singletonList(deSortField));
|
datasetGroupInfoDTO.setSortFields(Collections.singletonList(deSortField));
|
||||||
|
sortDistinct = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
Field2SQLObj.field2sqlObj(sqlMeta, fields, datasetGroupInfoDTO.getAllFields(), crossDs, dsMap);
|
Field2SQLObj.field2sqlObj(sqlMeta, fields, datasetGroupInfoDTO.getAllFields(), crossDs, dsMap);
|
||||||
ExtWhere2Str.extWhere2sqlOjb(sqlMeta, extFilterList, datasetGroupInfoDTO.getAllFields(), crossDs, dsMap);
|
ExtWhere2Str.extWhere2sqlOjb(sqlMeta, extFilterList, datasetGroupInfoDTO.getAllFields(), crossDs, dsMap);
|
||||||
WhereTree2Str.transFilterTrees(sqlMeta, rowPermissionsTree, fields, crossDs, dsMap);
|
WhereTree2Str.transFilterTrees(sqlMeta, rowPermissionsTree, fields, crossDs, dsMap);
|
||||||
Order2SQLObj.getOrders(sqlMeta, fields, datasetGroupInfoDTO.getSortFields(), crossDs, dsMap);
|
Order2SQLObj.getOrders(sqlMeta, fields, datasetGroupInfoDTO.getSortFields(), crossDs, dsMap);
|
||||||
String querySQL = SQLProvider.createQuerySQLWithLimit(sqlMeta, ids.size() == 1, needOrder, ids.size() == 1, 0, 1000);
|
String querySQL = SQLProvider.createQuerySQLWithLimit(sqlMeta, false, needOrder, sortDistinct && ids.size() == 1, 0, 1000);
|
||||||
querySQL = SqlUtils.rebuildSQL(querySQL, sqlMeta, crossDs, dsMap);
|
querySQL = SqlUtils.rebuildSQL(querySQL, sqlMeta, crossDs, dsMap);
|
||||||
logger.info("calcite data enum sql: " + querySQL);
|
logger.info("calcite data enum sql: " + querySQL);
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user