Commit 15743bcf9198f9abe181d55996470692a173a3ce

Authored by Andrii Shvaika
1 parent 931c7409

Fetch Last Level Only + Distinct values

... ... @@ -225,9 +225,9 @@ public class DefaultEntityQueryRepository implements EntityQueryRepository {
225 225 " INNER JOIN related_entities re ON" +
226 226 " r.$in_id = re.$out_id and r.$in_type = re.$out_type and" +
227 227 " relation_type_group = 'COMMON' %s)" +
228   - " SELECT re.$out_id entity_id, re.$out_type entity_type, re.lvl lvl" +
  228 + " SELECT re.$out_id entity_id, re.$out_type entity_type, max(re.lvl) lvl" +
229 229 " from related_entities re" +
230   - " %s ) entity";
  230 + " %s GROUP BY entity_id, entity_type) entity";
231 231 private static final String HIERARCHICAL_TO_QUERY_TEMPLATE = HIERARCHICAL_QUERY_TEMPLATE.replace("$in", "to").replace("$out", "from");
232 232 private static final String HIERARCHICAL_FROM_QUERY_TEMPLATE = HIERARCHICAL_QUERY_TEMPLATE.replace("$in", "from").replace("$out", "to");
233 233
... ... @@ -457,8 +457,6 @@ public class DefaultEntityQueryRepository implements EntityQueryRepository {
457 457
458 458 private String entitySearchQuery(QueryContext ctx, EntitySearchQueryFilter entityFilter, EntityType entityType, List<String> types) {
459 459 EntityId rootId = entityFilter.getRootEntity();
460   - //TODO: fetch last level only.
461   - //TODO: fetch distinct records.
462 460 String lvlFilter = getLvlFilter(entityFilter.getMaxLevel());
463 461 String selectFields = "SELECT tenant_id, customer_id, id, created_time, type, name, additional_info "
464 462 + (entityType.equals(EntityType.ENTITY_VIEW) ? "" : ", label ")
... ... @@ -470,7 +468,9 @@ public class DefaultEntityQueryRepository implements EntityQueryRepository {
470 468 whereFilter += " re.relation_type = :where_relation_type AND";
471 469 }
472 470 whereFilter += " re." + (entityFilter.getDirection().equals(EntitySearchDirection.FROM) ? "to" : "from") + "_type = :where_entity_type";
473   -
  471 + if (entityFilter.isFetchLastLevelOnly()) {
  472 + whereFilter += " and re.lvl = " + entityFilter.getMaxLevel();
  473 + }
474 474 from = String.format(from, lvlFilter, whereFilter);
475 475 String query = "( " + selectFields + from + ")";
476 476 if (types != null && !types.isEmpty()) {
... ... @@ -500,7 +500,7 @@ public class DefaultEntityQueryRepository implements EntityQueryRepository {
500 500 ctx.addStringParameter("relation_root_type", rootId.getEntityType().name());
501 501
502 502 StringBuilder whereFilter = new StringBuilder();
503   - ;
  503 +
504 504 boolean noConditions = true;
505 505 if (entityFilter.getFilters() != null && !entityFilter.getFilters().isEmpty()) {
506 506 boolean single = entityFilter.getFilters().size() == 1;
... ... @@ -530,6 +530,9 @@ public class DefaultEntityQueryRepository implements EntityQueryRepository {
530 530 .append("_type in (:where_entity_types").append(")");
531 531 ctx.addStringListParameter("where_entity_types", Arrays.stream(RELATION_QUERY_ENTITY_TYPES).map(EntityType::name).collect(Collectors.toList()));
532 532 }
  533 + if (entityFilter.isFetchLastLevelOnly()) {
  534 + whereFilter.append(" and re.lvl = ").append(entityFilter.getMaxLevel());
  535 + }
533 536 from = String.format(from, lvlFilter, whereFilter);
534 537 return "( " + selectFields + from + ")";
535 538 }
... ...