Skip to content

Commit

Permalink
parser: Add user defined column families to CTAS.
Browse files Browse the repository at this point in the history
This change introduces grammar to support user defined
column families. We are able to entirely piggyback on
the existing CREATE TABLE logic handling this, and thus
there are no changes outside of `pkg/parser`.
Added logic tests to verify behavior.

Release note (sql change): CREATE TABLE ... AS allows user defined
column families.
  • Loading branch information
adityamaru27 committed Jul 16, 2019
1 parent f8333e7 commit 07db8f2
Show file tree
Hide file tree
Showing 4 changed files with 99 additions and 6 deletions.
6 changes: 5 additions & 1 deletion docs/generated/sql/bnf/stmt_block.bnf
Original file line number Diff line number Diff line change
Expand Up @@ -1694,7 +1694,7 @@ partition_by ::=
| 'PARTITION' 'BY' 'NOTHING'

create_as_table_defs ::=
( column_name create_as_col_qual_list ) ( ( ',' create_as_constraint_def | ',' column_name create_as_col_qual_list ) )*
( column_name create_as_col_qual_list ) ( ( ',' column_name create_as_col_qual_list | ',' family_def | ',' create_as_constraint_def ) )*

common_table_expr ::=
table_alias_name opt_column_list 'AS' '(' preparable_stmt ')'
Expand Down Expand Up @@ -2136,6 +2136,10 @@ range_partition ::=

create_as_col_qualification ::=
create_as_col_qualification_elem
| 'FAMILY' family_name
| 'CREATE' 'FAMILY' family_name
| 'CREATE' 'FAMILY'
| 'CREATE' 'IF' 'NOT' 'EXISTS' 'FAMILY' family_name

create_as_constraint_elem ::=
'PRIMARY' 'KEY' '(' create_as_params ')'
Expand Down
62 changes: 62 additions & 0 deletions pkg/sql/logictest/testdata/logic_test/create_as
Original file line number Diff line number Diff line change
Expand Up @@ -236,3 +236,65 @@ foo11 CREATE TABLE foo11 (
statement error pq: multiple primary keys for table "foo12" are not allowed
CREATE TABLE foo12 (x PRIMARY KEY, y, PRIMARY KEY(y)) AS VALUES (1, 2), (3, 4);

# Check that CREATE TABLE AS allows users to specify column families.
statement ok
CREATE TABLE abcd(
a INT PRIMARY KEY,
b INT,
c INT,
d INT
);

# Test column qualifiers to define column families.
statement ok
CREATE TABLE foo12 (a PRIMARY KEY FAMILY f1, b, c CREATE FAMILY, d) AS SELECT * FROM abcd;

query TT
SHOW CREATE TABLE foo12
----
foo12 CREATE TABLE foo12 (
a INT8 NOT NULL,
b INT8 NULL,
c INT8 NULL,
d INT8 NULL,
CONSTRAINT "primary" PRIMARY KEY (a ASC),
FAMILY f1 (a, b, d),
FAMILY fam_1_c (c)
)

# Test constraint style definition of column families.
statement ok
CREATE TABLE foo13 (a, b, c, d, PRIMARY KEY(a, b), FAMILY pk (a, b), FAMILY (c, d)) AS SELECT * FROM abcd;

query TT
SHOW CREATE TABLE foo13
----
foo13 CREATE TABLE foo13 (
a INT8 NOT NULL,
b INT8 NOT NULL,
c INT8 NULL,
d INT8 NULL,
CONSTRAINT "primary" PRIMARY KEY (a ASC, b ASC),
FAMILY pk (a, b),
FAMILY fam_1_c_d (c, d)
)

# Test renaming columns still preserves the column families.
statement ok
ALTER TABLE foo13 RENAME d TO z

statement ok
ALTER TABLE foo13 RENAME c TO e

query TT
SHOW CREATE TABLE foo13
----
foo13 CREATE TABLE foo13 (
a INT8 NOT NULL,
b INT8 NOT NULL,
e INT8 NULL,
z INT8 NULL,
CONSTRAINT "primary" PRIMARY KEY (a ASC, b ASC),
FAMILY pk (a, b),
FAMILY fam_1_c_d (e, z)
)
7 changes: 7 additions & 0 deletions pkg/sql/parser/parse_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -257,6 +257,13 @@ func TestParse(t *testing.T) {
{`CREATE TABLE IF NOT EXISTS a (z PRIMARY KEY) AS SELECT * FROM b`},
{`CREATE TABLE a (x, y, z, PRIMARY KEY (x, y, z)) AS SELECT * FROM b`},
{`CREATE TABLE IF NOT EXISTS a (x, y, z, PRIMARY KEY (x, y, z)) AS SELECT * FROM b`},
{`CREATE TABLE a (x, FAMILY (x)) AS SELECT * FROM b`},
{`CREATE TABLE IF NOT EXISTS a (x, FAMILY (x)) AS SELECT * FROM b`},
{`CREATE TABLE a (x, y FAMILY f1) AS SELECT * FROM b`},
{`CREATE TABLE IF NOT EXISTS a (x, y FAMILY f1) AS SELECT * FROM b`},
{`CREATE TABLE a (x CREATE FAMILY) AS SELECT * FROM b`},
{`CREATE TABLE IF NOT EXISTS a (x CREATE FAMILY) AS SELECT * FROM b`},

{`CREATE TABLE a (b STRING COLLATE de)`},
{`CREATE TABLE a (b STRING(3) COLLATE de)`},
{`CREATE TABLE a (b STRING[] COLLATE de)`},
Expand Down
30 changes: 25 additions & 5 deletions pkg/sql/parser/sql.y
Original file line number Diff line number Diff line change
Expand Up @@ -4443,11 +4443,6 @@ create_as_table_defs:
var colToTableDef tree.TableDef = tableDef
$$.val = tree.TableDefs{colToTableDef}
}
| create_as_table_defs ',' create_as_constraint_def
{
var constraintToTableDef tree.TableDef = $3.constraintDef()
$$.val = append($1.tblDefs(), constraintToTableDef)
}
| create_as_table_defs ',' column_name create_as_col_qual_list
{
tableDef, err := tree.NewColumnTableDef(tree.Name($3), nil, false, $4.colQuals())
Expand All @@ -4459,6 +4454,15 @@ create_as_table_defs:

$$.val = append($1.tblDefs(), colToTableDef)
}
| create_as_table_defs ',' family_def
{
$$.val = append($1.tblDefs(), $3.tblDef())
}
| create_as_table_defs ',' create_as_constraint_def
{
var constraintToTableDef tree.TableDef = $3.constraintDef()
$$.val = append($1.tblDefs(), constraintToTableDef)
}

create_as_constraint_def:
create_as_constraint_elem
Expand Down Expand Up @@ -4508,6 +4512,22 @@ create_as_col_qualification:
{
$$.val = tree.NamedColumnQualification{Qualification: $1.colQualElem()}
}
| FAMILY family_name
{
$$.val = tree.NamedColumnQualification{Qualification: &tree.ColumnFamilyConstraint{Family: tree.Name($2)}}
}
| CREATE FAMILY family_name
{
$$.val = tree.NamedColumnQualification{Qualification: &tree.ColumnFamilyConstraint{Family: tree.Name($3), Create: true}}
}
| CREATE FAMILY
{
$$.val = tree.NamedColumnQualification{Qualification: &tree.ColumnFamilyConstraint{Create: true}}
}
| CREATE IF NOT EXISTS FAMILY family_name
{
$$.val = tree.NamedColumnQualification{Qualification: &tree.ColumnFamilyConstraint{Family: tree.Name($6), Create: true, IfNotExists: true}}
}

create_as_col_qualification_elem:
PRIMARY KEY
Expand Down

0 comments on commit 07db8f2

Please sign in to comment.