From 518f642028654befbaa09c328b7ccaf30ffd6f63 Mon Sep 17 00:00:00 2001 From: Clint Wylie Date: Mon, 19 Aug 2024 23:02:45 -0700 Subject: [PATCH] remove isDescending from Query interface, move to TimeseriesQuery (#16917) * remove isDescending from Query interface, since it is only actually settable and usable by TimeseriesQuery --- .../MaterializedViewQuery.java | 6 ------ .../org/apache/druid/query/BaseQuery.java | 21 ++++--------------- .../java/org/apache/druid/query/Query.java | 2 -- .../druid/query/groupby/GroupByQuery.java | 2 +- .../druid/query/search/SearchQuery.java | 2 +- .../druid/query/select/SelectQuery.java | 6 ------ .../query/timeseries/TimeseriesQuery.java | 20 +++++++++++++++++- .../TimeseriesQueryQueryToolChest.java | 2 +- .../apache/druid/query/topn/TopNQuery.java | 2 +- .../query/topn/TopNQueryQueryToolChest.java | 2 +- .../apache/druid/query/QueryContextTest.java | 6 ------ .../server/log/LoggingRequestLogger.java | 1 - .../server/log/LoggingRequestLoggerTest.java | 5 ----- 13 files changed, 28 insertions(+), 49 deletions(-) diff --git a/extensions-contrib/materialized-view-selection/src/main/java/org/apache/druid/query/materializedview/MaterializedViewQuery.java b/extensions-contrib/materialized-view-selection/src/main/java/org/apache/druid/query/materializedview/MaterializedViewQuery.java index d771667f6ea..ec061370a4d 100644 --- a/extensions-contrib/materialized-view-selection/src/main/java/org/apache/druid/query/materializedview/MaterializedViewQuery.java +++ b/extensions-contrib/materialized-view-selection/src/main/java/org/apache/druid/query/materializedview/MaterializedViewQuery.java @@ -146,12 +146,6 @@ public class MaterializedViewQuery implements Query return query.getContext(); } - @Override - public boolean isDescending() - { - return query.isDescending(); - } - @Override public Ordering getResultOrdering() { diff --git a/processing/src/main/java/org/apache/druid/query/BaseQuery.java b/processing/src/main/java/org/apache/druid/query/BaseQuery.java index f25a5ef317e..bbfa570e309 100644 --- a/processing/src/main/java/org/apache/druid/query/BaseQuery.java +++ b/processing/src/main/java/org/apache/druid/query/BaseQuery.java @@ -57,7 +57,6 @@ public abstract class BaseQuery implements Query public static final String SUB_QUERY_ID = "subQueryId"; public static final String SQL_QUERY_ID = "sqlQueryId"; private final DataSource dataSource; - private final boolean descending; private final QueryContext context; private final QuerySegmentSpec querySegmentSpec; private volatile Duration duration; @@ -69,13 +68,12 @@ public abstract class BaseQuery implements Query Map context ) { - this(dataSource, querySegmentSpec, false, context, Granularities.ALL); + this(dataSource, querySegmentSpec, context, Granularities.ALL); } public BaseQuery( DataSource dataSource, QuerySegmentSpec querySegmentSpec, - boolean descending, Map context, Granularity granularity ) @@ -87,7 +85,6 @@ public abstract class BaseQuery implements Query this.dataSource = dataSource; this.context = QueryContext.of(context); this.querySegmentSpec = querySegmentSpec; - this.descending = descending; this.granularity = granularity; } @@ -98,14 +95,6 @@ public abstract class BaseQuery implements Query return dataSource; } - @JsonProperty - @Override - @JsonInclude(Include.NON_DEFAULT) - public boolean isDescending() - { - return descending; - } - @JsonProperty("intervals") public QuerySegmentSpec getQuerySegmentSpec() { @@ -205,8 +194,7 @@ public abstract class BaseQuery implements Query @SuppressWarnings("unchecked") // assumes T is Comparable; see method javadoc public Ordering getResultOrdering() { - Ordering retVal = Ordering.natural(); - return descending ? retVal.reverse() : retVal; + return (Ordering) Ordering.natural(); } @Nullable @@ -253,8 +241,7 @@ public abstract class BaseQuery implements Query BaseQuery baseQuery = (BaseQuery) o; // Must use getDuration() instead of "duration" because duration is lazily computed. - return descending == baseQuery.descending && - Objects.equals(dataSource, baseQuery.dataSource) && + return Objects.equals(dataSource, baseQuery.dataSource) && Objects.equals(context, baseQuery.context) && Objects.equals(querySegmentSpec, baseQuery.querySegmentSpec) && Objects.equals(getDuration(), baseQuery.getDuration()) && @@ -265,6 +252,6 @@ public abstract class BaseQuery implements Query public int hashCode() { // Must use getDuration() instead of "duration" because duration is lazily computed. - return Objects.hash(dataSource, descending, context, querySegmentSpec, getDuration(), granularity); + return Objects.hash(dataSource, context, querySegmentSpec, getDuration(), granularity); } } diff --git a/processing/src/main/java/org/apache/druid/query/Query.java b/processing/src/main/java/org/apache/druid/query/Query.java index fa1f42d4c13..4795ecbb561 100644 --- a/processing/src/main/java/org/apache/druid/query/Query.java +++ b/processing/src/main/java/org/apache/druid/query/Query.java @@ -166,8 +166,6 @@ public interface Query return context().getHumanReadableBytes(key, defaultValue); } - boolean isDescending(); - /** * Comparator that represents the order in which results are generated from the * {@link QueryRunnerFactory#createRunner(Segment)} and diff --git a/processing/src/main/java/org/apache/druid/query/groupby/GroupByQuery.java b/processing/src/main/java/org/apache/druid/query/groupby/GroupByQuery.java index 761aa43b1b3..35510d7c5ee 100644 --- a/processing/src/main/java/org/apache/druid/query/groupby/GroupByQuery.java +++ b/processing/src/main/java/org/apache/druid/query/groupby/GroupByQuery.java @@ -202,7 +202,7 @@ public class GroupByQuery extends BaseQuery final Map context ) { - super(dataSource, querySegmentSpec, false, context, granularity); + super(dataSource, querySegmentSpec, context, granularity); this.virtualColumns = VirtualColumns.nullToEmpty(virtualColumns); this.dimFilter = dimFilter; diff --git a/processing/src/main/java/org/apache/druid/query/search/SearchQuery.java b/processing/src/main/java/org/apache/druid/query/search/SearchQuery.java index 7424bbf1fbc..aa10b6ab579 100644 --- a/processing/src/main/java/org/apache/druid/query/search/SearchQuery.java +++ b/processing/src/main/java/org/apache/druid/query/search/SearchQuery.java @@ -68,7 +68,7 @@ public class SearchQuery extends BaseQuery> @JsonProperty("context") Map context ) { - super(dataSource, querySegmentSpec, false, context, Granularities.nullToAll(granularity)); + super(dataSource, querySegmentSpec, context, Granularities.nullToAll(granularity)); Preconditions.checkNotNull(querySegmentSpec, "Must specify an interval"); this.dimFilter = dimFilter; diff --git a/processing/src/main/java/org/apache/druid/query/select/SelectQuery.java b/processing/src/main/java/org/apache/druid/query/select/SelectQuery.java index 606ccbeb357..c24f6f344bd 100644 --- a/processing/src/main/java/org/apache/druid/query/select/SelectQuery.java +++ b/processing/src/main/java/org/apache/druid/query/select/SelectQuery.java @@ -110,12 +110,6 @@ public class SelectQuery implements Query throw new RuntimeException(REMOVED_ERROR_MESSAGE); } - @Override - public boolean isDescending() - { - throw new RuntimeException(REMOVED_ERROR_MESSAGE); - } - @Override public Ordering getResultOrdering() { diff --git a/processing/src/main/java/org/apache/druid/query/timeseries/TimeseriesQuery.java b/processing/src/main/java/org/apache/druid/query/timeseries/TimeseriesQuery.java index 85ddf5aaa62..6e2cb62adcf 100644 --- a/processing/src/main/java/org/apache/druid/query/timeseries/TimeseriesQuery.java +++ b/processing/src/main/java/org/apache/druid/query/timeseries/TimeseriesQuery.java @@ -25,6 +25,7 @@ import com.fasterxml.jackson.annotation.JsonProperty; import com.fasterxml.jackson.annotation.JsonTypeName; import com.google.common.base.Preconditions; import com.google.common.collect.ImmutableList; +import com.google.common.collect.Ordering; import org.apache.commons.lang.StringUtils; import org.apache.druid.java.util.common.granularity.Granularity; import org.apache.druid.query.BaseQuery; @@ -68,6 +69,7 @@ public class TimeseriesQuery extends BaseQuery> private final DimFilter dimFilter; private final List aggregatorSpecs; private final List postAggregatorSpecs; + private final boolean descending; private final int limit; @JsonCreator @@ -84,7 +86,7 @@ public class TimeseriesQuery extends BaseQuery> @JsonProperty("context") Map context ) { - super(dataSource, querySegmentSpec, descending, context, granularity); + super(dataSource, querySegmentSpec, context, granularity); // The below should be executed after context is initialized. final String timestampField = getTimestampResultField(); @@ -97,6 +99,7 @@ public class TimeseriesQuery extends BaseQuery> this.aggregatorSpecs, postAggregatorSpecs == null ? ImmutableList.of() : postAggregatorSpecs ); + this.descending = descending; this.limit = (limit == 0) ? Integer.MAX_VALUE : limit; Preconditions.checkArgument(this.limit > 0, "limit must be greater than 0"); } @@ -148,6 +151,13 @@ public class TimeseriesQuery extends BaseQuery> return postAggregatorSpecs; } + @JsonProperty + @JsonInclude(JsonInclude.Include.NON_DEFAULT) + public boolean isDescending() + { + return descending; + } + @JsonProperty("limit") @JsonInclude(value = JsonInclude.Include.CUSTOM, valueFilter = LimitJsonIncludeFilter.class) public int getLimit() @@ -155,6 +165,7 @@ public class TimeseriesQuery extends BaseQuery> return limit; } + public boolean isGrandTotal() { return context().getBoolean(CTX_GRAND_TOTAL, false); @@ -195,6 +206,13 @@ public class TimeseriesQuery extends BaseQuery> ); } + @Override + public Ordering> getResultOrdering() + { + Ordering> retVal = Ordering.natural(); + return descending ? retVal.reverse() : retVal; + } + @Override public TimeseriesQuery withQuerySegmentSpec(QuerySegmentSpec querySegmentSpec) { diff --git a/processing/src/main/java/org/apache/druid/query/timeseries/TimeseriesQueryQueryToolChest.java b/processing/src/main/java/org/apache/druid/query/timeseries/TimeseriesQueryQueryToolChest.java index 3ad58270f8b..05b25d05c21 100644 --- a/processing/src/main/java/org/apache/druid/query/timeseries/TimeseriesQueryQueryToolChest.java +++ b/processing/src/main/java/org/apache/druid/query/timeseries/TimeseriesQueryQueryToolChest.java @@ -228,7 +228,7 @@ public class TimeseriesQueryQueryToolChest extends QueryToolChest> createResultComparator(Query> query) { - return ResultGranularTimestampComparator.create(query.getGranularity(), query.isDescending()); + return ResultGranularTimestampComparator.create(query.getGranularity(), ((TimeseriesQuery) query).isDescending()); } private Result getNullTimeseriesResultValue(TimeseriesQuery query) diff --git a/processing/src/main/java/org/apache/druid/query/topn/TopNQuery.java b/processing/src/main/java/org/apache/druid/query/topn/TopNQuery.java index 2534c37f90f..3178ac15a18 100644 --- a/processing/src/main/java/org/apache/druid/query/topn/TopNQuery.java +++ b/processing/src/main/java/org/apache/druid/query/topn/TopNQuery.java @@ -76,7 +76,7 @@ public class TopNQuery extends BaseQuery> @JsonProperty("context") Map context ) { - super(dataSource, querySegmentSpec, false, context, granularity); + super(dataSource, querySegmentSpec, context, granularity); Preconditions.checkNotNull(dimensionSpec, "dimensionSpec can't be null"); Preconditions.checkNotNull(topNMetricSpec, "must specify a metric"); diff --git a/processing/src/main/java/org/apache/druid/query/topn/TopNQueryQueryToolChest.java b/processing/src/main/java/org/apache/druid/query/topn/TopNQueryQueryToolChest.java index c5f195615f3..501684dce40 100644 --- a/processing/src/main/java/org/apache/druid/query/topn/TopNQueryQueryToolChest.java +++ b/processing/src/main/java/org/apache/druid/query/topn/TopNQueryQueryToolChest.java @@ -124,7 +124,7 @@ public class TopNQueryQueryToolChest extends QueryToolChest> delegateRunner = new ResultMergeQueryRunner<>( runner, - query -> ResultGranularTimestampComparator.create(query.getGranularity(), query.isDescending()), + query -> ResultGranularTimestampComparator.create(query.getGranularity(), false), query -> { TopNQuery topNQuery = (TopNQuery) query; return new TopNBinaryFn( diff --git a/processing/src/test/java/org/apache/druid/query/QueryContextTest.java b/processing/src/test/java/org/apache/druid/query/QueryContextTest.java index c555c2ed437..d0d6a512627 100644 --- a/processing/src/test/java/org/apache/druid/query/QueryContextTest.java +++ b/processing/src/test/java/org/apache/druid/query/QueryContextTest.java @@ -464,12 +464,6 @@ public class QueryContextTest return context; } - @Override - public boolean isDescending() - { - return false; - } - @Override public Ordering getResultOrdering() { diff --git a/server/src/main/java/org/apache/druid/server/log/LoggingRequestLogger.java b/server/src/main/java/org/apache/druid/server/log/LoggingRequestLogger.java index 4a8b946eecc..08e8e92d739 100644 --- a/server/src/main/java/org/apache/druid/server/log/LoggingRequestLogger.java +++ b/server/src/main/java/org/apache/druid/server/log/LoggingRequestLogger.java @@ -68,7 +68,6 @@ public class LoggingRequestLogger implements RequestLogger MDC.put("hasFilters", Boolean.toString(query.hasFilters())); MDC.put("remoteAddr", requestLogLine.getRemoteAddr()); MDC.put("duration", query.getDuration().toString()); - MDC.put("descending", Boolean.toString(query.isDescending())); if (setContextMDC) { final Iterable> entries = query.getContext() == null ? ImmutableList.of() diff --git a/server/src/test/java/org/apache/druid/server/log/LoggingRequestLoggerTest.java b/server/src/test/java/org/apache/druid/server/log/LoggingRequestLoggerTest.java index 0ee15ab1f3f..3dc9696d4f4 100644 --- a/server/src/test/java/org/apache/druid/server/log/LoggingRequestLoggerTest.java +++ b/server/src/test/java/org/apache/druid/server/log/LoggingRequestLoggerTest.java @@ -219,7 +219,6 @@ public class LoggingRequestLoggerTest Assert.assertEquals("false", map.get("hasFilters")); Assert.assertEquals("fake", map.get("queryType")); Assert.assertEquals("some.host.tld", map.get("remoteAddr")); - Assert.assertEquals("false", map.get("descending")); Assert.assertEquals("false", map.get("isNested")); Assert.assertNull(map.get("foo")); } @@ -235,7 +234,6 @@ public class LoggingRequestLoggerTest Assert.assertEquals("false", map.get("hasFilters")); Assert.assertEquals("fake", map.get("queryType")); Assert.assertEquals("some.host.tld", map.get("remoteAddr")); - Assert.assertEquals("false", map.get("descending")); Assert.assertEquals("false", map.get("isNested")); Assert.assertEquals("bar", map.get("foo")); } @@ -256,7 +254,6 @@ public class LoggingRequestLoggerTest Assert.assertEquals("false", map.get("hasFilters")); Assert.assertEquals("fake", map.get("queryType")); Assert.assertEquals("some.host.tld", map.get("remoteAddr")); - Assert.assertEquals("false", map.get("descending")); Assert.assertEquals("true", map.get("isNested")); Assert.assertNull(map.get("foo")); } @@ -278,7 +275,6 @@ public class LoggingRequestLoggerTest Assert.assertEquals("fake", map.get("queryType")); Assert.assertEquals("some.host.tld", map.get("remoteAddr")); Assert.assertEquals("true", map.get("isNested")); - Assert.assertEquals("false", map.get("descending")); Assert.assertNull(map.get("foo")); } @@ -299,7 +295,6 @@ public class LoggingRequestLoggerTest Assert.assertEquals("false", map.get("hasFilters")); Assert.assertEquals("fake", map.get("queryType")); Assert.assertEquals("some.host.tld", map.get("remoteAddr")); - Assert.assertEquals("false", map.get("descending")); Assert.assertNull(map.get("foo")); }