Skip to content

Commit

Permalink
opt: include optional columns when remapping Project provided ordering
Browse files Browse the repository at this point in the history
This commit fixes a bug that was recently introduced in #87562 that can
cause an internal panic when remapping an ordering from the input to the
output of a `Project` operator. #87562 modified the logic to ensure that
the remapping only refers to columns from the required ordering; however,
it failed to add the optional columns to the allowed set of columns. This
could cause a panic if the provided ordering contains columns from the
optional set. This is fixed by adding the optional columns when remapping.

Fixes #87806

Release note: None (only on master)
  • Loading branch information
DrewKimball committed Sep 12, 2022
1 parent 7bcbc70 commit 24640d5
Show file tree
Hide file tree
Showing 2 changed files with 44 additions and 1 deletion.
2 changes: 1 addition & 1 deletion pkg/sql/opt/ordering/project.go
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,7 @@ func projectBuildProvided(expr memo.RelExpr, required *props.OrderingChoice) opt
// can cause the child to provide an ordering that is equivalent to the
// required ordering, but which the parent Project cannot prove is equivalent
// because its FDs have less information. This can lead to a panic later on.
ordCols := required.ColSet()
ordCols := required.ColSet().Union(required.Optional)
if !ordCols.SubsetOf(expr.Relational().OutputCols) {
panic(errors.AssertionFailedf("expected required columns to be a subset of output columns"))
}
Expand Down
43 changes: 43 additions & 0 deletions pkg/sql/opt/xform/testdata/physprops/ordering
Original file line number Diff line number Diff line change
Expand Up @@ -2931,3 +2931,46 @@ project
│ └── bool_and
└── projections
└── NULL

# Regression test for #87806 - include optional columns when remapping Project
# provided ordering.
exec-ddl
CREATE TABLE table87806 (
col1_0 TIMESTAMPTZ, col1_1 BOOL, col1_2 REGPROC, col1_3 REGNAMESPACE,
PRIMARY KEY (col1_1, col1_2 ASC),
UNIQUE (col1_1 ASC),
INDEX (col1_3)
);
----

opt format=hide-all
SELECT tab_171969.col1_3
FROM table87806 AS tab_171967
JOIN table87806 AS tab_171968
JOIN table87806@table87806_col1_3_idx AS tab_171969
ON tab_171968.col1_1 = tab_171969.col1_1
AND tab_171968.col1_3 = tab_171969.col1_3
AND tab_171968.col1_3 = tab_171969.tableoid
ON tab_171967.col1_2 = tab_171968.tableoid
AND tab_171967.col1_3 = tab_171968.col1_3
WHERE tab_171967.col1_1
ORDER BY tab_171969.col1_1 ASC;
----
project
└── inner-join (lookup table87806@table87806_col1_3_idx [as=tab_171967])
├── lookup columns are key
├── project
│ ├── inner-join (lookup table87806 [as=tab_171968])
│ │ ├── lookup columns are key
│ │ ├── select
│ │ │ ├── index-join table87806
│ │ │ │ └── scan table87806@table87806_col1_3_idx [as=tab_171969]
│ │ │ │ ├── constraint: /16/14/15: (/NULL - ]
│ │ │ │ └── flags: force-index=table87806_col1_3_idx
│ │ │ └── filters
│ │ │ └── tab_171969.col1_3 = tab_171969.tableoid
│ │ └── filters
│ │ └── tab_171968.col1_3 = tab_171969.col1_3
│ └── projections
│ └── true
└── filters (true)

0 comments on commit 24640d5

Please sign in to comment.