[
https://issues.apache.org/jira/browse/CALCITE-5230?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17578096#comment-17578096
]
Julian Hyde commented on CALCITE-5230:
--------------------------------------
{quote}Are you suggesting to create a named sub-class SqlPercentileBinding and
a new SqlReturnTypeInference which would use the new binding class?{quote}
Yes. Creating a new {{SqlReturnTypeInference}} is very common. Creating a new
sub-class of {{SqlCallBinding}} is less common but seems justified.
> PERCENTILE_DISC return type derivation
> --------------------------------------
>
> Key: CALCITE-5230
> URL: https://issues.apache.org/jira/browse/CALCITE-5230
> Project: Calcite
> Issue Type: Bug
> Reporter: Itiel Sadeh
> Assignee: Itiel Sadeh
> Priority: Major
> Labels: pull-request-available
> Fix For: 1.32.0
>
> Time Spent: 10m
> Remaining Estimate: 0h
>
> In the following expression:
> {code:java}
> PERCENTILE_DISC ( numeric_literal ) WITHIN GROUP ( ORDER BY
> order_by_expression) {code}
> the return type of `PERCENTILE_DISC` aggregate function is hard-coded as
> `DOUBLE`,
> while in Postgresql and MSSQL it is determined by the `order_by_expression`
> type.
> Currently there is no way to derive the correct type of `PERCENTILE_DISC`
> function from the `order_by_expression` type, as this expression is not an
> argument for the `PERCENTILE_DISC` function.
> Calcite is creating the following tree from this expression:
> {code:java}
> SqlCall(operator: WITHING_GROUP, operands: [SqlCall( operator:
> PERCENTILE_DISC, operands: [numeric_literal], order_by_expression]){code}
> for correct type derivation, the order_by_expression should be an operand of
> the PERCENTILE_DISC call
--
This message was sent by Atlassian Jira
(v8.20.10#820010)