Adam Kennedy created CALCITE-6340: ------------------------------------- Summary: RelBuilder always creates Project with Convention.NONE during aggregate_ Key: CALCITE-6340 URL: https://issues.apache.org/jira/browse/CALCITE-6340 Project: Calcite Issue Type: Bug Components: core Affects Versions: 1.36.0 Reporter: Adam Kennedy
In the RelBuilder method aggregate_, when (config.pruneInputOfAggregate() && r instanceof Project) line 2443 the Project will be rewritten to remove unused columns. When this happens, the new Project will be created with the following line {{{}2487: r = {}}}{{{}2488: project.copy(cluster.traitSet(), project.getInput(), newProjects,{}}} {{2489: builder.build());}} The use of cluster.traitSet() returns emptyTraitSet which is always going to use Convention.NONE regardless of the Rebuilder's ProjectFactory. In the case of a query plan using a non-Logical convention FOO, with FooProject nodes that require the FOO convention, RelBuilder will normally happily produce FooProject nodes with FOO convention, allowing many CoreRules to be easily reused for custom Conventions. However, while RelBuilder will produce FooProject with FOO convention in the majority of cases, for the one specific case of column pruning a Project input to an aggregate, it will instead product a FooProject with NONE convention. -- This message was sent by Atlassian Jira (v8.20.10#820010)