You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@calcite.apache.org by "Julian Hyde (Jira)" <ji...@apache.org> on 2021/03/19 19:35:00 UTC

[jira] [Commented] (CALCITE-4541) group by numerical literal will collide with group by ordinal in default sql validator

    [ https://issues.apache.org/jira/browse/CALCITE-4541?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17305153#comment-17305153 ] 

Julian Hyde commented on CALCITE-4541:
--------------------------------------

Thanks for finding this. Clearly a bug.

I'm not sure of a fix. We need to be careful that we deduce that we are grouping by an ordinal BEFORE we expand GROUP BY expressions from the SELECT clause.

I strongly suspect that this behavior only occurs if {{SqlConformance.isGroupByAlias()}} is true, which is not the default. Looking for calls to this method may give clues as to where the bug is.

> group by numerical literal will collide with group by ordinal in default sql validator
> --------------------------------------------------------------------------------------
>
>                 Key: CALCITE-4541
>                 URL: https://issues.apache.org/jira/browse/CALCITE-4541
>             Project: Calcite
>          Issue Type: Bug
>          Components: core
>    Affects Versions: 1.26.0
>         Environment: open-jdk8
>            Reporter: yanjing.wang
>            Priority: Major
>             Fix For: 1.27.0
>
>
> {code:java}
> String sql = "select 20210101 as ds , count(distinct id) as c from users where ds = 20210101 group by ds";
> {code}
>  
> 'group by ds' expression will be expanded to 'group by 20210101' at line 'expandGroupByOrHavingExpr' of 'validateGroupClause(SqlSelect select)' method.
>  
> but when GroupByScope 'validateExpr(SqlNode expr)', it will check if 'group by 20210101' is a group by ordinal literal such as 'group by 1, 2' etc. . and in 'visit(SqlLiteral literal)' method of 'ExtendedExpander' class does this. 
>  
> the problem raises when check if it is a 'group by ordinal', it only has a condition 
>  
> {code:java}
> boolean isOrdinalLiteral = literal == root;  
> {code}
> this is always true in this scenario.
>  
> it raise exception 'SqlValidatorException: Ordinal out of range when executing following code.
> {code:java}
> if (intValue < 1 || intValue > select.getSelectList().size()) { throw validator.newValidationError(literal, RESOURCE.orderByOrdinalOutOfRange()); }{code}
>  
> I think whether we need check 'originalExprs' instance variable of sqlValidatorImpl class contains the literal. if so, it can be verified as not an ordinal. but I'm not sure whether this approach is correct.
>  
>  
>  



--
This message was sent by Atlassian Jira
(v8.3.4#803005)