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 d771667f6eaa..ec061370a4d7 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 Map getContext() 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 f25a5ef317ea..bbfa570e3094 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 static void checkInterrupted() 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 BaseQuery( 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 BaseQuery( this.dataSource = dataSource; this.context = QueryContext.of(context); this.querySegmentSpec = querySegmentSpec; - this.descending = descending; this.granularity = granularity; } @@ -98,14 +95,6 @@ public DataSource getDataSource() return dataSource; } - @JsonProperty - @Override - @JsonInclude(Include.NON_DEFAULT) - public boolean isDescending() - { - return descending; - } - @JsonProperty("intervals") public QuerySegmentSpec getQuerySegmentSpec() { @@ -205,8 +194,7 @@ public static Map computeOverriddenContext( @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 boolean equals(Object o) 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 boolean equals(Object o) 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 fa1f42d4c13d..4795ecbb5611 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 @@ default HumanReadableBytes getContextHumanReadableBytes(String key, HumanReadabl 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 761aa43b1b3f..35510d7c5eea 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 @@ private GroupByQuery( 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 7424bbf1fbcc..aa10b6ab5790 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 SearchQuery( @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 606ccbeb3573..c24f6f344bd0 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 Map getContext() 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 85ddf5aaa62f..6e2cb62adcf9 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.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 TimeseriesQuery( @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 TimeseriesQuery( 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 List getPostAggregatorSpecs() 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 int getLimit() return limit; } + public boolean isGrandTotal() { return context().getBoolean(CTX_GRAND_TOTAL, false); @@ -195,6 +206,13 @@ public Set getRequiredColumns() ); } + @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 3ad58270f8b7..05b25d05c219 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 BinaryOperator> createMergeFn( @Override public Comparator> 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 2534c37f90f6..3178ac15a183 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 TopNQuery( @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 c5f195615f36..501684dce40e 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 QueryRunner> mergeResults(QueryRunner> 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 c555c2ed4372..d0d6a5126278 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 Map getContext() 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 4a8b946eecc8..08e8e92d739a 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 void logNativeQuery(RequestLogLine requestLogLine) throws IOException 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 0ee15ab1f3f2..3dc9696d4f4c 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 void testLoggingMDC() throws Exception 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 void testLoggingMDCContext() throws Exception 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 void testNestedQueryLoggingMDC() throws Exception 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 void testNestedNestedQueryLoggingMDC() throws Exception 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 void testUnionQueryLoggingMDC() throws Exception 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")); }