[ https://issues.apache.org/jira/browse/CALCITE-3583?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17417862#comment-17417862 ]
Julian Hyde commented on CALCITE-3583: -------------------------------------- Can you change the subject to "Externalize Exchange operator to and from JSON"? "Serialize" misleadingly implies that we are using Java serialization ({{interface Serializable}}). > Support serialized to json and deserialized from json for Exchange relation > operator > ------------------------------------------------------------------------------------ > > Key: CALCITE-3583 > URL: https://issues.apache.org/jira/browse/CALCITE-3583 > Project: Calcite > Issue Type: Improvement > Reporter: Wang Yanlin > Priority: Major > Labels: pull-request-available > Time Spent: 3h > Remaining Estimate: 0h > > Currently, serialize Exchange relnode to json will cause exception > {code:java} > // RelWriterTest > @Test public void testExchange() { > final FrameworkConfig config = RelBuilderTest.config().build(); > final RelBuilder builder = RelBuilder.create(config); > final RelNode rel = builder > .scan("EMP") > .exchange(RelDistributions.hash(ImmutableList.of(0, 1))) > .build(); > String relJson = RelOptUtil.dumpPlan("", rel, > SqlExplainFormat.JSON, SqlExplainLevel.EXPPLAN_ATTRIBUTES); > String s = deserializeAndDumpToTextFormat(getSchema(rel), relJson); > final String expected = "" > + "LogicalExchange(distribution=[hash[0, 1]])\n" > + " LogicalTableScan(table=[[scott, EMP]])\n"; > assertThat(s, isLinux(expected)); > } > {code} > got > {code:java} > java.lang.UnsupportedOperationException: type not serializable: hash[0, 1] > (type org.apache.calcite.rel.RelDistributions.RelDistributionImpl) > at org.apache.calcite.rel.externalize.RelJson.toJson(RelJson.java:290) > at > org.apache.calcite.rel.externalize.RelJsonWriter.put(RelJsonWriter.java:83) > at > org.apache.calcite.rel.externalize.RelJsonWriter.explain_(RelJsonWriter.java:66) > at > org.apache.calcite.rel.externalize.RelJsonWriter.done(RelJsonWriter.java:128) > at > org.apache.calcite.rel.AbstractRelNode.explain(AbstractRelNode.java:299) > at org.apache.calcite.plan.RelOptUtil.dumpPlan(RelOptUtil.java:1981) > at > org.apache.calcite.plan.RelWriterTest.testExchange(RelWriterTest.java:772) > {code} -- This message was sent by Atlassian Jira (v8.3.4#803005)