CREATE COLLECTION AS Statements
- Capella Columnar
- reference
This topic describes how you use the CREATE COLLECTION AS
statement to both create a standalone collection and populate it with the results of a query.
Syntax
CreateCollectionAs EBNF
CreateCollectionAs ::= "CREATE" "ANALYTICS"? "COLLECTION" ("IF" "NOT" "EXISTS")?
QualifiedName
"PRIMARY" "KEY" "(" FieldList ")" ( "AUTOGENERATED" )?
"AS"
"SelectClause"
CreateCollectionAs Diagram
data:image/s3,"s3://crabby-images/effbb/effbb2ba6c95c05cea00ddcc0d58c305f810649e" alt=""CREATE" "COLLECTION" ("IF" "NOT" "EXISTS")? QualifiedName "PRIMARY" "KEY" "(" FieldList ")" ( "AUTOGENERATED" )? "AS" "SelectClause""
Show SelectClause Diagram
data:image/s3,"s3://crabby-images/ffe06/ffe0680312714d0646b43df29452b440f2a62fa9" alt="SELECT"
Show Projection Diagram
data:image/s3,"s3://crabby-images/72b17/72b1796cd98b35b0ac35300a4b53fe9dd76a05db" alt="(Expr ("AS"? Identifier)?) | (VariableRef ".")? "*""
For more information about SELECT clause syntax, see Queries.
Example
In this example, you create a standalone collection, travel-sample.inventory.restaurants
and specify that you want the system to autogenerate its primary key.
You then select a subset of the documents—those with an activity of eat—in the existing travel-sample.inventory.landmark
sample data collection to populate the new collection.
CREATE COLLECTION `travel-sample`.inventory.restaurants
PRIMARY KEY (restId: UUID) AUTOGENERATED
AS
SELECT *
FROM `travel-sample`.inventory.landmark
WHERE activity = "eat";
After you use CREATE COLLECTION AS
, you can run ANALYZE COLLECTION
on the collection to update the data sample used by cost-based optimization (CBO).
See Cost-Based Optimizer for Capella Columnar Services.