diff --git a/pkg/sql/opt/ordering/project.go b/pkg/sql/opt/ordering/project.go index b824cfba05ce..ac906a43212f 100644 --- a/pkg/sql/opt/ordering/project.go +++ b/pkg/sql/opt/ordering/project.go @@ -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")) } diff --git a/pkg/sql/opt/xform/testdata/physprops/ordering b/pkg/sql/opt/xform/testdata/physprops/ordering index 53f6f66406b5..ab277f1e108b 100644 --- a/pkg/sql/opt/xform/testdata/physprops/ordering +++ b/pkg/sql/opt/xform/testdata/physprops/ordering @@ -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)