Check out v4 of the Fauna CLI
v4 of the Fauna CLI is now in beta. The new version introduces enhancements to the developer experience, including an improved authentication workflow. To get started, check out the CLI v4 quick start. |
Collection
Learn: Collections |
---|
We recommend you use FSL to create and update user-defined collections. See FSL collection schema. |
You add data to Fauna as JSON-like documents, stored in collections.
Collection
collection
Fauna stores user-defined collections as
documents in the Collection
system collection. These documents have the
CollectionDef type and are an FQL version of the FSL
collection schema.
Collection
documents have the following FQL structure:
{
name: "Customer",
alias: "Cust",
coll: Collection,
ts: Time("2099-10-03T20:45:53.780Z"),
computed_fields: {
cart: {
body: "(customer) => Order.byCustomerAndStatus(customer, \"cart\").first()",
signature: "Order?"
},
orders: {
body: "(customer) => Order.byCustomer(customer)",
signature: "Set<Order>"
}
},
fields: {
name: {
signature: "String"
},
email: {
signature: "String"
},
address: {
signature: "{ street: String, city: String, state: String, postalCode: String, country: String }"
}
},
migrations: [
{
add_wildcard: {}
}
],
wildcard: "Any",
history_days: 0,
ttl_days: 10,
document_ttls: true,
indexes: {
byEmail: {
terms: [
{
field: ".email",
mva: false
}
],
values: [
{
field: ".email",
order: "desc",
mva: false
},
{
field: ".name",
order: "asc",
mva: false
}
],
queryable: true,
status: "complete"
},
},
constraints: [
{
unique: [
{
field: ".email",
mva: false
}
],
status: "active"
}
],
data: {
desc: "The Customer collection definition"
}
}
Field | Type | Read-only | Required | Description |
---|---|---|---|---|
|
true |
Name of the collection. |
||
|
Alias used to reference a collection with a name that conflicts with a reserved schema name. By creating and using an alias, the resource doesn’t have to be renamed. See Schema aliasing. |
|||
|
true |
Collection name: |
||
|
true |
Last time the document was created or updated. |
||
|
FQL version of the collection schema’s computed fields. See FSL collection schema: Computed field definitions |
|||
|
FQL version of the collection schema’s field definitions. See FSL collection schema: Field definitions. |
|||
|
FQL version of the collection schema’s migrations block. See FSL collection schema: Migrations block. |
|||
|
FQL version of the collection schema’s wildcard constraint. See Wildcard constraints. |
|||
|
Number of days of history to retain for collection documents. When the number of days lapses, document snapshots older than the interval are removed. Does not affect the current version of documents. Defaults to |
|||
|
Documents are deleted Defaults to |
|||
|
If true, you can write to the
|
|||
|
FQL version of the collection schema’s index definitions. See Index definitions.
|
|||
|
FQL version of the collection schema’s check and unique constraints. See FSL collection schema: Check constraint definitions and FSL collection schema: Unique constraint definitions. |
|||
|
|
Arbitrary user-defined metadata for the document. |
indexes
build fields
indexes
objects include fields you can use to monitor the
index build:
Field | Type | Read-only | Required | Description |
---|---|---|---|---|
|
true |
If true, the index is queryable. If false, the index is not queryable. |
||
|
Union of |
true |
Status of the index build.
Possible values are |
Static methods
You can use the following static methods to manage the Collection
collection in FQL.
Method | Description |
---|---|
Access a collection by its name. |
|
Get a Set of all collection definitions. |
|
Get a collection definitions by its name. |
|
Create a collection. |
|
Get the first collection definition that matches a provided predicate. |
|
Get |
|
Get a Set of collection definitions that match a provided predicate. |
Instance properties
Collection
documents have the following properties. You
access the property using an existing collection’s name.
Property | Description |
---|---|
Get a collection definition, represented
as a |
Instance methods
You can use the following instance methods to manage collection definitions,
represented as Collection
documents, in FQL. You call the methods on a
CollectionDef.
Method | Description |
---|---|
Delete a collection. |
|
Test if a collection exists. |
|
Replaces a collection definition. |
|
Update a collection definition. |
Collection name methods
You can use the following collection name methods to create and manage documents within a user-defined collection using FQL. You call the methods directly on an existing collection’s name.
Method | Description |
---|---|
Get a Set of all documents in a collection. |
|
Get a collection document by its
document |
|
Create a collection document. |
|
Create a collection document from an object that may contain metadata fields. |
|
Get the first collection document that matches a provided predicate. |
|
Get a Set of collection documents that match a provided predicate. |
|
Call an index as a method to get a Set of matching collection documents. |
Is this article helpful?
Tell Fauna how the article can be improved:
Visit Fauna's forums
or email docs@fauna.com
Thank you for your feedback!