skip expression virtual column indexes when mvd is used as array (#15644)

This commit is contained in:
Clint Wylie 2024-01-08 21:22:37 -08:00 committed by GitHub
parent 911941b4a6
commit cafc748f7e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 19 additions and 2 deletions

View File

@ -34,6 +34,7 @@ import org.apache.druid.segment.column.ColumnIndexSupplier;
import org.apache.druid.segment.column.ColumnType; import org.apache.druid.segment.column.ColumnType;
import org.apache.druid.segment.index.semantic.DictionaryEncodedValueIndex; import org.apache.druid.segment.index.semantic.DictionaryEncodedValueIndex;
import org.apache.druid.segment.serde.NoIndexesColumnIndexSupplier; import org.apache.druid.segment.serde.NoIndexesColumnIndexSupplier;
import org.apache.druid.segment.virtual.ExpressionSelectors;
import javax.annotation.Nullable; import javax.annotation.Nullable;
import java.util.ArrayList; import java.util.ArrayList;
@ -213,6 +214,11 @@ public interface Expr extends Cacheable
); );
final ColumnCapabilities capabilities = columnIndexSelector.getColumnCapabilities(column); final ColumnCapabilities capabilities = columnIndexSelector.getColumnCapabilities(column);
if (!ExpressionSelectors.canMapOverDictionary(details, capabilities)) {
// for mvds, expression might need to evaluate entire row, but we don't have those handy, so fall back to
// not using indexes
return NoIndexesColumnIndexSupplier.getInstance();
}
final ExpressionType inputType = ExpressionType.fromColumnTypeStrict(capabilities); final ExpressionType inputType = ExpressionType.fromColumnTypeStrict(capabilities);
final ColumnType outType; final ColumnType outType;
if (outputType == null) { if (outputType == null) {
@ -509,8 +515,8 @@ public interface Expr extends Cacheable
* @see Parser#applyUnappliedBindings * @see Parser#applyUnappliedBindings
* @see Parser#applyUnapplied * @see Parser#applyUnapplied
* @see Parser#liftApplyLambda * @see Parser#liftApplyLambda
* @see org.apache.druid.segment.virtual.ExpressionSelectors#makeDimensionSelector * @see ExpressionSelectors#makeDimensionSelector
* @see org.apache.druid.segment.virtual.ExpressionSelectors#makeColumnValueSelector * @see ExpressionSelectors#makeColumnValueSelector
*/ */
@SuppressWarnings("JavadocReference") @SuppressWarnings("JavadocReference")
class BindingAnalysis class BindingAnalysis

View File

@ -147,6 +147,7 @@ public abstract class BaseFilterTest extends InitializedNullHandlingTest
new ExpressionVirtualColumn("double-vf0-add-sub", "vf0 + (vf0 - vf0)", ColumnType.FLOAT, TestExprMacroTable.INSTANCE), new ExpressionVirtualColumn("double-vf0-add-sub", "vf0 + (vf0 - vf0)", ColumnType.FLOAT, TestExprMacroTable.INSTANCE),
new ExpressionVirtualColumn("double-vl0-add-sub", "vl0 + (vl0 - vl0)", ColumnType.LONG, TestExprMacroTable.INSTANCE), new ExpressionVirtualColumn("double-vl0-add-sub", "vl0 + (vl0 - vl0)", ColumnType.LONG, TestExprMacroTable.INSTANCE),
new ExpressionVirtualColumn("vdim3-concat", "dim3 + dim3", ColumnType.LONG, TestExprMacroTable.INSTANCE), new ExpressionVirtualColumn("vdim3-concat", "dim3 + dim3", ColumnType.LONG, TestExprMacroTable.INSTANCE),
new ExpressionVirtualColumn("vdim2-offset", "array_offset(dim2, 1)", ColumnType.STRING, TestExprMacroTable.INSTANCE),
new ExpressionVirtualColumn("nestedArrayLong", "array(arrayLong)", ColumnType.ofArray(ColumnType.LONG_ARRAY), TestExprMacroTable.INSTANCE), new ExpressionVirtualColumn("nestedArrayLong", "array(arrayLong)", ColumnType.ofArray(ColumnType.LONG_ARRAY), TestExprMacroTable.INSTANCE),
new ListFilteredVirtualColumn("allow-dim0", DefaultDimensionSpec.of("dim0"), ImmutableSet.of("3", "4"), true), new ListFilteredVirtualColumn("allow-dim0", DefaultDimensionSpec.of("dim0"), ImmutableSet.of("3", "4"), true),
new ListFilteredVirtualColumn("deny-dim0", DefaultDimensionSpec.of("dim0"), ImmutableSet.of("3", "4"), false), new ListFilteredVirtualColumn("deny-dim0", DefaultDimensionSpec.of("dim0"), ImmutableSet.of("3", "4"), false),

View File

@ -483,6 +483,16 @@ public class EqualityFilterTests
: ImmutableList.of("0", "2", "3", "4") : ImmutableList.of("0", "2", "3", "4")
); );
} }
// array_offset behaves same on both mvds and arrays
assertFilterMatchesSkipVectorize(
new EqualityFilter("vdim2-offset", ColumnType.STRING, "b", null),
ImmutableList.of("0")
);
assertFilterMatchesSkipVectorize(
NotDimFilter.of(new EqualityFilter("vdim2-offset", ColumnType.STRING, "b", null)),
NullHandling.sqlCompatible() ? ImmutableList.of() : ImmutableList.of("1", "2", "3", "4", "5")
);
} }
@Test @Test