You are viewing a plain text version of this content. The canonical link for it is here.
Posted to issues@calcite.apache.org by "xzh_dz (Jira)" <ji...@apache.org> on 2020/09/12 13:01:00 UTC
[jira] [Commented] (CALCITE-4250) Failed to get original column of
aggregate operator
[ https://issues.apache.org/jira/browse/CALCITE-4250?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=17194730#comment-17194730 ]
xzh_dz commented on CALCITE-4250:
---------------------------------
!image-2020-09-12-20-58-06-444.png!
`7` means that the deptno column's position in the `scott.EMP`table.
> Failed to get original column of aggregate operator
> ---------------------------------------------------
>
> Key: CALCITE-4250
> URL: https://issues.apache.org/jira/browse/CALCITE-4250
> Project: Calcite
> Issue Type: Wish
> Reporter: xzh_dz
> Priority: Major
> Labels: pull-request-available
> Attachments: image-2020-09-12-20-58-06-444.png
>
> Time Spent: 0.5h
> Remaining Estimate: 0h
>
> We often use `RelMetadataQuery` to track column lineage, but failed to get original column of aggregate operator.
> This case can be reproduced as below, the correct column index is 7, but got 5.
> {code:java}
> // @Test void testAggregateRelMdColumnOrigins() {
> final RelBuilder relBuilder = RelBuilder.create(config().build());
> final LogicalProject project = (LogicalProject) relBuilder.scan("EMP")
> .project(relBuilder.field("EMPNO"),
> relBuilder.field("ENAME"),
> relBuilder.field("JOB"),
> relBuilder.field("SAL"),
> relBuilder.field("DEPTNO")).build();
> final LogicalAggregate aggregate = (LogicalAggregate) relBuilder.push(project)
> .aggregate(
> relBuilder.groupKey(relBuilder.field(1, 0, "DEPTNO")),
> relBuilder.count(relBuilder.field(1, 0, "SAL")))
> .build();
> RelMetadataQuery mq = aggregate.getCluster().getMetadataQuery();
> final RelColumnOrigin nameColumn = mq.getColumnOrigin(aggregate , 0);
> assertThat(nameColumn.getOriginTable().getRowType().getFieldNames().get(7).equals("DEPTNO"), is(true));
> System.out.println(nameColumn.getOriginColumnOrdinal()); // 5
> }
> {code}
--
This message was sent by Atlassian Jira
(v8.3.4#803005)