Skip to content

Commit

Permalink
Allow DESC ordering in window expressions
Browse files Browse the repository at this point in the history
* allow DESC ordering in window expressions
* allow and accept NULLS FIRST / NULLS LAST options if they align with the actual ordering mode ; and report if they are unsupported
  • Loading branch information
kgyrtkirk committed Oct 18, 2023
1 parent 0a27a7a commit 8b61e7c
Show file tree
Hide file tree
Showing 6 changed files with 142 additions and 92 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,12 @@
import org.apache.calcite.adapter.java.JavaTypeFactory;
import org.apache.calcite.prepare.BaseDruidSqlValidator;
import org.apache.calcite.prepare.CalciteCatalogReader;
import org.apache.calcite.sql.SqlCall;
import org.apache.calcite.sql.SqlKind;
import org.apache.calcite.sql.SqlNode;
import org.apache.calcite.sql.SqlOperatorTable;
import org.apache.calcite.sql.validate.SqlValidatorScope;
import org.apache.druid.error.InvalidSqlInput;

/**
* Druid extended SQL validator. (At present, it doesn't actually
Expand All @@ -39,4 +44,23 @@ protected DruidSqlValidator(
{
super(opTab, catalogReader, typeFactory, validatorConfig);
}

@Override
public void validateCall(SqlCall call, SqlValidatorScope scope)
{
if (call.getKind() == SqlKind.NULLS_FIRST) {
SqlNode op0 = call.getOperandList().get(0);
if (op0.getKind() == SqlKind.DESCENDING) {
throw InvalidSqlInput.exception("DESCENDING ordering with NULLS FIRST is not supported!");
}
}
if (call.getKind() == SqlKind.NULLS_LAST) {
SqlNode op0 = call.getOperandList().get(0);
if (op0.getKind() != SqlKind.DESCENDING) {
throw InvalidSqlInput.exception("ASCENDING ordering with NULLS LAST is not supported!");
}
}

super.validateCall(call, scope);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,9 @@ public class DruidConvertletTable implements SqlRexConvertletTable
.add(SqlStdOperatorTable.NULLIF)
.add(SqlStdOperatorTable.COALESCE)
.add(SqlLibraryOperators.NVL)
.add(SqlStdOperatorTable.DESC)
.add(SqlStdOperatorTable.NULLS_FIRST)
.add(SqlStdOperatorTable.NULLS_LAST)
.build();

private final Map<SqlOperator, SqlRexConvertlet> table;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -137,6 +137,9 @@
import java.util.Map;
import java.util.stream.Collectors;

import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertThrows;

public class CalciteQueryTest extends BaseCalciteQueryTest
{
@Test
Expand Down Expand Up @@ -14247,4 +14250,24 @@ public void testLatestByOnStringColumnWithoutMaxBytesSpecified()
new Object[] {"abc", defaultString, "def", defaultString, "def", defaultString}
));
}

@Test
public void testUnSupportedNullsFirst()
{
DruidException e = assertThrows(DruidException.class, () -> testBuilder()
.queryContext(ImmutableMap.of(PlannerContext.CTX_ENABLE_WINDOW_FNS, true))
.sql("SELECT dim1,ROW_NUMBER() OVER (ORDER BY dim1 DESC NULLS FIRST) from druid.foo")
.run());
assertEquals("DESCENDING ordering with NULLS FIRST is not supported!", e.getMessage());
}

@Test
public void testUnSupportedNullsLast()
{
DruidException e = assertThrows(DruidException.class, () -> testBuilder()
.queryContext(ImmutableMap.of(PlannerContext.CTX_ENABLE_WINDOW_FNS, true))
.sql("SELECT dim1,ROW_NUMBER() OVER (ORDER BY dim1 NULLS LAST) from druid.foo")
.run());
assertEquals("ASCENDING ordering with NULLS LAST is not supported!", e.getMessage());
}
}
Loading

0 comments on commit 8b61e7c

Please sign in to comment.