[
https://issues.apache.org/jira/browse/CALCITE-5349?page=com.atlassian.jira.plugin.system.issuetabpanels:all-tabpanel
]
Julian Hyde resolved CALCITE-5349.
----------------------------------
Fix Version/s: 1.33.0
Resolution: Fixed
Fixed in
[02b67eae|https://github.com/apache/calcite/commit/02b67eae841c093d966bdb6371381be234c275d6];
thanks for the fix, [~tjbanghart]!
In {{RelJson}}, the fix adds a {{create()}} method and deprecates the
constructor; adds methods {{withOperatorTable}}, {{withLibraryOperatorTable}},
{{withJsonBuilder}} to further control its behavior. The fix adds an argument
to {{RelJsonWriter}} and {{RelJsonReader}} constructors to allow configuring
their embedded {{RelJson}} object.
> RelJson should support non-standard operators
> ---------------------------------------------
>
> Key: CALCITE-5349
> URL: https://issues.apache.org/jira/browse/CALCITE-5349
> Project: Calcite
> Issue Type: Improvement
> Components: core
> Reporter: TJ Banghart
> Assignee: TJ Banghart
> Priority: Minor
> Labels: pull-request-available
> Fix For: 1.33.0
>
> Time Spent: 10m
> Remaining Estimate: 0h
>
> I am attempting to deserialize {{RexNodes}} that contain non-standard
> operators but {{RexJson#toOp}} only considers operators found in
> {{{}SqlStdOperatorTable{}}}:
> [https://github.com/apache/calcite/blob/c945b7f49b99538748c871557f6ac80957be2b6e/core/src/main/java/org/apache/calcite/rel/externalize/RelJson.java#L780]
> For example, attempting to deserialize a JSON RexCall that includes the
> BigQuery only `DATE_FROM_UNIX_DATE` operator raises {{CalciteException: No
> operator for 'DATE_FROM_UNIX_DATE' with kind: 'OTHER_FUNCTION', syntax:
> 'FUNCTION' during JSON deserialization}}
> Unless I am missing something, I don't believe the operator lookup is
> configurable or overridable.
--
This message was sent by Atlassian Jira
(v8.20.10#820010)