Skip to content

Commit

Permalink
Merge pull request #61104 from mgartner/backport20.2-60590
Browse files Browse the repository at this point in the history
release-20.2: sql: fix SHOW CREATE output for partitioned and interleaved partial indexes
  • Loading branch information
mgartner authored Feb 26, 2021
2 parents 973e3f0 + a5b94af commit c1074c3
Show file tree
Hide file tree
Showing 7 changed files with 120 additions and 23 deletions.
8 changes: 6 additions & 2 deletions pkg/ccl/importccl/read_import_mysql_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -216,11 +216,15 @@ func compareTables(t *testing.T, expected, got *descpb.TableDescriptor) {
tableName := &descpb.AnonymousTable
expectedDesc := tabledesc.NewImmutable(*expected)
gotDesc := tabledesc.NewImmutable(*got)
e, err := schemaexpr.FormatIndexForDisplay(ctx, expectedDesc, tableName, &expected.Indexes[i], &semaCtx)
e, err := schemaexpr.FormatIndexForDisplay(
ctx, expectedDesc, tableName, &expected.Indexes[i], "" /* partition */, "" /* interleave */, &semaCtx,
)
if err != nil {
t.Fatalf("unexpected error: %s", err)
}
g, err := schemaexpr.FormatIndexForDisplay(ctx, gotDesc, tableName, &got.Indexes[i], &semaCtx)
g, err := schemaexpr.FormatIndexForDisplay(
ctx, gotDesc, tableName, &got.Indexes[i], "" /* partition */, "" /* interleave */, &semaCtx,
)
if err != nil {
t.Fatalf("unexpected error: %s", err)
}
Expand Down
28 changes: 28 additions & 0 deletions pkg/ccl/logictestccl/testdata/logic_test/partitioning_index
Original file line number Diff line number Diff line change
Expand Up @@ -150,3 +150,31 @@ indexes CREATE TABLE public.indexes (
FAMILY "primary" (a, b)
)
-- Warning: Partitioned table with no zone configurations.

# Regression test for #60019. The index predicate should be formatted after the
# PARTITION BY clause to match the syntax that is accepted.
statement ok
CREATE TABLE t60019 (
pk INT PRIMARY KEY,
a INT,
b INT,
INDEX (a, b) PARTITION BY LIST (a) (
PARTITION c_implicit VALUES IN (3)
) WHERE b > 0,
FAMILY (pk, a, b)
)

query T
SELECT create_statement FROM [SHOW CREATE TABLE t60019]
----
CREATE TABLE public.t60019 (
pk INT8 NOT NULL,
a INT8 NULL,
b INT8 NULL,
CONSTRAINT "primary" PRIMARY KEY (pk ASC),
INDEX t60019_a_b_idx (a ASC, b ASC) PARTITION BY LIST (a) (
PARTITION c_implicit VALUES IN ((3))
) WHERE b > 0:::INT8,
FAMILY fam_0_pk_a_b (pk, a, b)
)
-- Warning: Partitioned table with no zone configurations.
4 changes: 3 additions & 1 deletion pkg/sql/crdb_internal.go
Original file line number Diff line number Diff line change
Expand Up @@ -1907,7 +1907,9 @@ func showCreateIndexWithInterleave(
semaCtx *tree.SemaContext,
) error {
f.WriteString("CREATE ")
idxStr, err := schemaexpr.FormatIndexForDisplay(ctx, table, &tableName, idx, semaCtx)
idxStr, err := schemaexpr.FormatIndexForDisplay(
ctx, table, &tableName, idx, "" /* partition */, "" /* interleave */, semaCtx,
)
if err != nil {
return err
}
Expand Down
21 changes: 21 additions & 0 deletions pkg/sql/logictest/testdata/logic_test/show_create
Original file line number Diff line number Diff line change
Expand Up @@ -30,3 +30,24 @@ c CREATE TABLE public.c (
COMMENT ON TABLE public.c IS 'table';
COMMENT ON COLUMN public.c.a IS 'column';
COMMENT ON INDEX public.c@c_a_b_idx IS 'index'

# Regression test for #60701. In the SHOW CREATE output of a table with a
# partial interleaved index, the INTERLEAVE clause should precede the WHERE
# clause. This matches the accepted syntax for creating partial interleaved
# indexes.
statement ok
CREATE TABLE t60701_a (a INT PRIMARY KEY, FAMILY (a));
CREATE TABLE t60701_b (b INT PRIMARY KEY, a INT REFERENCES t60701_a (a), FAMILY (b, a));
CREATE INDEX i ON t60701_b (a) INTERLEAVE IN PARENT t60701_a (a) WHERE b > 0;

query T
SELECT create_statement FROM [SHOW CREATE TABLE t60701_b]
----
CREATE TABLE public.t60701_b (
b INT8 NOT NULL,
a INT8 NULL,
CONSTRAINT "primary" PRIMARY KEY (b ASC),
CONSTRAINT fk_a_ref_t60701_a FOREIGN KEY (a) REFERENCES public.t60701_a(a),
INDEX i (a ASC) INTERLEAVE IN PARENT public.t60701_a (a) WHERE b > 0:::INT8,
FAMILY fam_0_b_a (b, a)
)
5 changes: 5 additions & 0 deletions pkg/sql/schemaexpr/partial_index.go
Original file line number Diff line number Diff line change
Expand Up @@ -99,6 +99,8 @@ func FormatIndexForDisplay(
table catalog.TableDescriptor,
tableName *tree.TableName,
index *descpb.IndexDescriptor,
partition string,
interleave string,
semaCtx *tree.SemaContext,
) (string, error) {
f := tree.NewFmtCtx(tree.FmtSimple)
Expand Down Expand Up @@ -134,6 +136,9 @@ func FormatIndexForDisplay(
f.WriteByte(')')
}

f.WriteString(interleave)
f.WriteString(partition)

if index.GeoConfig.S2Geometry != nil || index.GeoConfig.S2Geography != nil {
var s2Config *geoindex.S2Config

Expand Down
45 changes: 35 additions & 10 deletions pkg/sql/schemaexpr/partial_index_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -152,21 +152,46 @@ func TestFormatIndexForDisplay(t *testing.T) {
partialIndex.Predicate = "a > 1:::INT8"

testData := []struct {
index descpb.IndexDescriptor
tableName tree.TableName
expected string
index descpb.IndexDescriptor
tableName tree.TableName
partition string
interleave string
expected string
}{
{baseIndex, descpb.AnonymousTable, "INDEX baz (a ASC, b DESC)"},
{baseIndex, tableName, "INDEX baz ON foo.public.bar (a ASC, b DESC)"},
{uniqueIndex, descpb.AnonymousTable, "UNIQUE INDEX baz (a ASC, b DESC)"},
{invertedIndex, descpb.AnonymousTable, "INVERTED INDEX baz (a)"},
{storingIndex, descpb.AnonymousTable, "INDEX baz (a ASC, b DESC) STORING (c)"},
{partialIndex, descpb.AnonymousTable, "INDEX baz (a ASC, b DESC) WHERE a > 1:::INT8"},
{baseIndex, descpb.AnonymousTable, "", "", "INDEX baz (a ASC, b DESC)"},
{baseIndex, tableName, "", "", "INDEX baz ON foo.public.bar (a ASC, b DESC)"},
{uniqueIndex, descpb.AnonymousTable, "", "", "UNIQUE INDEX baz (a ASC, b DESC)"},
{invertedIndex, descpb.AnonymousTable, "", "", "INVERTED INDEX baz (a)"},
{storingIndex, descpb.AnonymousTable, "", "", "INDEX baz (a ASC, b DESC) STORING (c)"},
{partialIndex, descpb.AnonymousTable, "", "", "INDEX baz (a ASC, b DESC) WHERE a > 1:::INT8"},
{
partialIndex,
descpb.AnonymousTable,
" PARTITION BY LIST (a) (PARTITION p VALUES IN (2))",
"",
"INDEX baz (a ASC, b DESC) PARTITION BY LIST (a) (PARTITION p VALUES IN (2)) WHERE a > 1:::INT8",
},
{
partialIndex,
descpb.AnonymousTable,
"",
" INTERLEAVE IN PARENT par (a)",
"INDEX baz (a ASC, b DESC) INTERLEAVE IN PARENT par (a) WHERE a > 1:::INT8",
},
{
partialIndex,
descpb.AnonymousTable,
" PARTITION BY LIST (a) (PARTITION p VALUES IN (2))",
" INTERLEAVE IN PARENT par (a)",
"INDEX baz (a ASC, b DESC) INTERLEAVE IN PARENT par (a) PARTITION BY LIST (a) (PARTITION p VALUES IN (2)) WHERE a > 1:::INT8",
},
}

for testIdx, tc := range testData {
t.Run(strconv.Itoa(testIdx), func(t *testing.T) {
got, err := schemaexpr.FormatIndexForDisplay(ctx, tableDesc, &tc.tableName, &tc.index, &semaCtx)
got, err := schemaexpr.FormatIndexForDisplay(
ctx, tableDesc, &tc.tableName, &tc.index, tc.partition, tc.interleave, &semaCtx,
)
if err != nil {
t.Fatalf("unexpected error: %s", err)
}
Expand Down
32 changes: 22 additions & 10 deletions pkg/sql/show_create.go
Original file line number Diff line number Diff line change
Expand Up @@ -159,27 +159,39 @@ func ShowCreateTable(
}
if idx.ID != desc.GetPrimaryIndex().ID && includeInterleaveClause {
// Showing the primary index is handled above.
f.WriteString(",\n\t")
idxStr, err := schemaexpr.FormatIndexForDisplay(ctx, desc, &descpb.AnonymousTable, idx, &p.RunParams(ctx).p.semaCtx)
if err != nil {

// Build the PARTITION BY clause.
var partitionBuf bytes.Buffer
if err := ShowCreatePartitioning(
a, p.ExecCfg().Codec, desc, idx, &idx.Partitioning, &partitionBuf, 1 /* indent */, 0, /* colOffset */
); err != nil {
return "", err
}
f.WriteString(idxStr)
// Showing the INTERLEAVE and PARTITION BY for the primary index are
// handled last.

// Add interleave or Foreign Key indexes only to the create_table columns,
// and not the create_nofks column.
var interleaveBuf bytes.Buffer
if includeInterleaveClause {
if err := showCreateInterleave(idx, &f.Buffer, dbPrefix, lCtx); err != nil {
if err := showCreateInterleave(idx, &interleaveBuf, dbPrefix, lCtx); err != nil {
return "", err
}
}
if err := ShowCreatePartitioning(
a, p.ExecCfg().Codec, desc, idx, &idx.Partitioning, &f.Buffer, 1 /* indent */, 0, /* colOffset */
); err != nil {

f.WriteString(",\n\t")
idxStr, err := schemaexpr.FormatIndexForDisplay(
ctx,
desc,
&descpb.AnonymousTable,
idx,
partitionBuf.String(),
interleaveBuf.String(),
p.RunParams(ctx).p.SemaCtx(),
)
if err != nil {
return "", err
}
f.WriteString(idxStr)

}
}

Expand Down

0 comments on commit c1074c3

Please sign in to comment.