ArangoDB v3.13 is under development and not released yet. This documentation is not final and potentially incomplete.
The collection object of the JavaScript API
Collection objects represent document collections and provide access to information and methods for executing collection-related operations
The JavaScript API returns collection objects when you use the following methods
of the db
object from the @arangodb
:
db._create(...)
db._createDocumentCollection(...)
db._createEdgeCollection(...)
db._collections(...)
db._collection(...)
Collection
collection.checksum([withRevisions [, withData]])
Calculate a checksum for the data in a collection:
The checksum
operation calculates an aggregate hash value for all document
keys contained in collection collection
.
If the optional argument withRevisions
is set to true
, then the
revision ids of the documents are also included in the hash calculation.
If the optional argument withData
is set to true
, then all user-defined
document attributes are also checksummed. Including the document data in
checksumming makes the calculation slower, but is more accurate.
collection.compact()
Compacts the data of a collection in order to reclaim disk space. The operation compacts the document and index data by rewriting the underlying .sst files and only keeps the relevant entries.
Under normal circumstances running a compact operation is not necessary, as the collection data is eventually compacted anyway. However, in some situations, e.g. after running lots of update/replace or remove operations, the disk data for a collection may contain a lot of outdated data for which the space shall be reclaimed. In this case the compaction operation can be used.
collection.drop([options])
Drops a collection
and all its indexes and data.
In order to drop a system collection, an options
object
with attribute isSystem
set to true
must be specified.
Examples
Drop a collection:
var coll = db.example;
coll.drop();
coll;
Drop a system collection:
var coll = db._example;
coll.drop({ isSystem: true });
collection.figures([details])
Returns an object containing statistics about the collection.
Setting details
to true
returns extended storage engine-specific
details to the figures (introduced in v3.8.0). The details are intended for
debugging ArangoDB itself and their format is subject to change. By default,
details
is set to false
, so no details are returned and the behavior is
identical to previous versions of ArangoDB.
indexes.count
: The total number of indexes defined for the collection, including the pre-defined indexes (e.g. primary index).indexes.size
: The total memory allocated for indexes in bytes.
documentsSize
cacheInUse
cacheSize
cacheUsage
Examples
Get the basic collection figures:
db.demo.figures()
Get the detailed collection figures:
db.demo.figures(true)
collection.getResponsibleShard(document)
Return the responsible shard for the given document.
Returns a string with the responsible shard’s ID. Note that the returned shard ID is the ID of responsible shard for the document’s shard key values, and it returns even if no such document exists.
getResponsibleShard()
method can only be used on Coordinators
in clusters.collection.load()
Loads a collection into memory.
load()
function is deprecated as of ArangoDB 3.8.0.
The function may be removed in future versions of ArangoDB. There should not be
any need to load a collection with the RocksDB storage engine.collection.name()
Returns the name of the collection as a string.
Examples
Get the collection name from a collection object:
var coll = db._create("example");
coll.name();
collection.properties([properties])
Get or set the properties of a collection.
collection.properties()
Returns an object containing all collection properties.
waitForSync
(boolean): Iftrue
, creating, changing, or removing documents waits until the data has been synchronized to disk.keyOptions
(object): An object which contains key generation options.type
(string): Specifies the type of the key generator. Possible values:"traditional"
"autoincrement"
"uuid"
"padded"
allowUserKeys
(boolean): If set totrue
, then you are allowed to supply own key values in the_key
attribute of documents. If set tofalse
, then the key generator is solely responsible for generating keys and an error is raised if you supply own key values in the_key
attribute of documents.You should not use both user-specified and automatically generated document keys in the same collection in cluster deployments for collections with more than a single shard. Mixing the two can lead to conflicts because Coordinators that auto-generate keys in this case are not aware of all keys which are already used.increment
(number): The increment value for theautoincrement
key generator. Not used by other key generator types.offset
(number): The initial offset value for theautoincrement
key generator. Not used by other key generator types.lastValue
(number): the offset value of theautoincrement
orpadded
key generator. This is an internal property for restoring dumps properly.
schema
(object|null): An object that specifies the collection-level document schema for documents. The attribute keysrule
,level
andmessage
must follow the rules documented in Document Schema ValidationcomputedValues
(array|null): An array of objects, each representing a Computed Value.cacheEnabled
(boolean): Whether the in-memory hash cache for documents is enabled for this collection (default:false
).isSystem
(boolean): Whether the collection is a system collection. Collection names that starts with an underscore are usually system collections.syncByRevision
(boolean): Whether the newer revision-based replication protocol is enabled for this collection. This is an internal property.globallyUniqueId
(string): A unique identifier of the collection. This is an internal property.
In a cluster setup, the result also contains the following attributes:
numberOfShards
(number): The number of shards of the collection.shardKeys
(array): Contains the names of document attributes that are used to determine the target shard for documents.replicationFactor
(number|string): Determines how many copies of each shard are kept on different DB-Servers. Has to be in the range of 1-10 or the string"satellite"
for a SatelliteCollection (Enterprise Edition only). (cluster only)writeConcern
(number): Determines how many copies of each shard are required to be in sync on the different DB-Servers. If there are less then these many copies in the cluster, a shard refuses to write. Writes to shards with enough up-to-date copies succeed at the same time, however. The value ofwriteConcern
cannot be greater thanreplicationFactor
. (cluster only)shardingStrategy
(string): the sharding strategy selected for the collection. (cluster only)Possible values:
"community-compat"
"enterprise-compat"
"enterprise-smart-edge-compat"
"hash"
"enterprise-hash-smart-edge"
"enterprise-hex-smart-vertex"
distributeShardsLike
(string): The name of another collection. This collection uses thereplicationFactor
,numberOfShards
andshardingStrategy
properties of the other collection and the shards of this collection are distributed in the same way as the shards of the other collection.isSmart
(boolean): Whether the collection is used in a SmartGraph or EnterpriseGraph (Enterprise Edition only). This is an internal property.isDisjoint
(boolean): Whether the SmartGraph this collection belongs to is disjoint (Enterprise Edition only). This is an internal property.smartGraphAttribute
(string): The attribute that is used for sharding: vertices with the same value of this attribute are placed in the same shard. All vertices are required to have this attribute set and it has to be a string. Edges derive the attribute from their connected vertices.This feature can only be used in the Enterprise Edition.
smartJoinAttribute
(string): In an Enterprise Edition cluster, this attribute determines an attribute of the collection that must contain the shard key value of the referred-to SmartJoin collection.
collection.properties(properties)
Changes the collection properties. properties
must be an object and can have
one or more of the following attribute(s):
waitForSync
(boolean): Iftrue
, creating a document only returns after the data was synced to disk.replicationFactor
(number|string): Change the number of shard copies kept on different DB-Servers. Valid values are integer numbers in the range of 1-10 or the string"satellite"
for a SatelliteCollection (Enterprise Edition only). (cluster only)writeConcern
(number): Change how many copies of each shard are required to be in sync on the different DB-Servers. If there are less then these many copies in the cluster, a shard refuses to write. Writes to shards with enough up-to-date copies succeed at the same time however. The value ofwriteConcern
cannot be greater thanreplicationFactor
. (cluster only)computedValues
(array|null): An array of objects, each representing a Computed Value.schema
(object|null): An object that specifies the collection level document schema for documents. The attribute keysrule
,level
andmessage
must follow the rules documented in Document Schema ValidationcacheEnabled
(boolean): Whether the in-memory hash cache for documents should be enabled for this collection. Can be controlled globally with the--cache.size
startup option. The cache can speed up repeated reads of the same documents via their document keys. If the same documents are not fetched often or are modified frequently, then you may disable the cache to avoid the maintenance costs.
type
,
keyOptions
, numberOfShards
or shardingStrategy
cannot be changed once
the collection is created.Examples
Read all properties:
db.example.properties();
Change a property:
db.example.properties({ waitForSync : true });
collection.rename(name)
Renames a collection. The new-name
must not already be
used for a different collection. new-name
must also be a valid collection name.
For information about the naming constraints for collections, see
Collection names.
If renaming fails for any reason, an error is thrown.
If renaming the collection succeeds, then the collection is also renamed in
all graph definitions inside the _graphs
collection in the current
database.
rename()
method cannot be used in clusters.Examples
var coll = db.example;
coll.rename("better-example");
coll;
collection.revision()
Returns the revision ID of the collection
The revision ID is updated when the document data is modified, either by inserting, deleting, updating or replacing documents in it.
The revision ID of a collection can be used by clients to check whether data in a collection has changed or if it is still unmodified since a previous fetch of the revision ID.
The revision ID returned is a string value. Clients should treat this value as an opaque string, and only use it for equality/non-equality comparisons.
collection.shards([details])
Return the available shards for the collection.
If details
is not set, or set to false
, returns an array with the names of
the available shards of the collection.
If details
is set to true
, returns an object with the shard names as
object attribute keys, and the responsible servers as an array mapped to each
shard attribute key.
The leader shards are always first in the arrays of responsible servers.
shards()
method can only be used on Coordinators in clusters.collection.truncate()
Truncates a collection
, removing all documents but keeping all its
indexes.
Examples
Truncates a collection:
var coll = db.example;
var doc = coll.save({ "Hello" : "World" });
coll.count();
coll.truncate();
coll.count();
collection.type()
Returns the type of a collection. Possible values are:
2
: document collection3
: edge collection
collection.unload()
Starts unloading a collection from memory. Note that unloading is deferred until all queries have finished.
unload()
function is deprecated as of ArangoDB 3.8.0.
The function may be removed in future versions of ArangoDB. There should not be
any need to unload a collection with the RocksDB storage engine.Indexes
collection.ensureIndex(description)
Creates an index if it doesn’t exist already.
collection.indexes([withStats [, withHidden]])
Lists all indexes of the collection.
See collection.indexes()
.
collection.getIndexes([withStats [, withHidden]])
Same as collection.indexes([withStats [, withHidden]])
.
collection.index(index)
Gets an index by identifier.
See collection.index()
.
collection.dropIndex(index)
Drops an index by identifier.
Documents
collection.all()
Fetches all documents from a collection and returns a cursor. You can use
toArray()
, next()
, or hasNext()
to access the result. The result
can be limited using the skip()
and limit()
operator.
Examples
Use toArray()
to get all documents at once:
var docs = db.five.insert([
{ name : "one" },
{ name : "two" },
{ name : "three" },
{ name : "four" },
{ name : "five" }
]);
db.five.all().toArray();
Use limit()
to restrict the documents:
var docs = db.five.insert([
{ name : "one" },
{ name : "two" },
{ name : "three" },
{ name : "four" },
{ name : "five" }
]);
db.five.all().limit(2).toArray();
collection.any()
Returns a random document from the collection or null
if none exists.
Note: This is generally an expensive operation for the RocksDB storage engine but ArangoDB uses an optimization for retrieving a single pseudo-random document.
collection.byExample(example)
Fetches all documents from a collection that match the specified example and returns a cursor.
You can use toArray()
, next()
, or hasNext()
to access the
result. The result can be limited using the skip()
and limit()
operator.
An attribute name of the form a.b
is interpreted as attribute path,
not as attribute. If you use
{ "a" : { "c" : 1 } }
as example, then you will find all documents, such that the attribute
a
contains a document of the form { "c" : 1 }
. For example the document
{ "a" : { "c" : 1 }, "b" : 1 }
will match, but the document
{ "a" : { "c" : 1, "b" : 1 } }
will not.
However, if you use
{ "a.c" : 1 }
then you will find all documents, which contain a sub-document in a
that has an attribute c
of value 1
. Both the following documents
{ "a" : { "c" : 1 }, "b" : 1 }
and
{ "a" : { "c" : 1, "b" : 1 } }
will match.
collection.byExample(path1, value1, ...)
As alternative you can supply an array of paths and values.
Examples
Use toArray()
to get all documents at once:
db.users.insert([
{ name: "Gerhard" },
{ name: "Helmut" },
{ name: "Angela" }
]);
db.users.all().toArray();
db.users.byExample({ "_id" : "users/20" }).toArray();
db.users.byExample({ "name" : "Gerhard" }).toArray();
db.users.byExample({ "name" : "Helmut", "_id" : "users/15" }).toArray();
Use next()
to loop over all documents:
db.users.insert([
{ name: "Gerhard" },
{ name: "Helmut" },
{ name: "Angela" }
]);
var cursor = db.users.byExample( {"name" : "Angela" } );
while (cursor.hasNext()) {
print(cursor.next());
}
collection.count()
Returns the number of living documents in the collection.
Examples
db.users.count();
collection.document(object [, options])
The document()
method finds a document given an object object
containing the _id
or _key
attribute. The method returns
the document if it can be found. If both attributes are given,
the _id
takes precedence, it is an error, if the collection part
of the _id
does not match the collection
.
An error is thrown if _rev
is specified but the document found has a
different revision already. An error is also thrown if no document exists
with the given _id
or _key
value.
Please note that if the method is executed on the arangod server (e.g. from
inside a Foxx application), an immutable document object will be returned
for performance reasons. It is not possible to change attributes of this
immutable object. To update or patch the returned document, it needs to be
cloned/copied into a regular JavaScript object first. This is not necessary
if the document
method is called from out of arangosh or from any other
client.
If you pass options
as the second argument, it must be an object.
- If the object has the
allowDirtyReads
attribute set totrue
, then the Coordinator is allowed to read from any shard replica and not only from the leader shard. See Read from followers for details.
collection.document(document-identifier [, options])
Finds a document using a document identifier, optionally with an options passed as an object.
No revision can be specified in this case.
collection.document(document-key [, options])
Finds a document using a document key, optionally with an options passed as an object.
No revision can be specified in this case.
collection.document(array [, options])
This variant allows you to perform the operation on a whole array of arguments.
The behavior is exactly as if document()
would have been called on all members
of the array separately and all results are returned in an array. If an error
occurs with any of the documents, no exception is raised! Instead of a document,
an error object is returned in the result array.
Examples
Return a document using a document identifier:
db.example.document("example/2873916");
Return a document using a document key:
db.example.document("2873916");
Return a document using an object with a document identifier:
db.example.document({_id: "example/2873916"});
Return multiple documents using an array of document keys:
db.example.document(["2873916","2873917"]);
An error is raised if the document is unknown:
db.example.document("example/4472917");
An error is raised if the document key or identifier is invalid:
db.example.document("");
collection.documents(keys)
Looks up the documents in the specified collection using the array of
keys provided. All documents for which a matching key was specified in
the keys
array and that exist in the collection will be returned. Keys
for which no document can be found in the underlying collection are
ignored, and no exception will be thrown for them.
document()
.Examples
var keys = [ ];
for (var i = 0; i < 5; ++i) {
db.example.insert({ _key: "test" + i, value: i });
keys.push("test" + i);
}
db.example.documents(keys);
collection.documentId(documentKey)
Converts a document key to a document identifier by prepending the collection’s name and a forward slash to the key.
Raises an error if the document key is invalid. Note that this method does not check whether the document exists in the collection.
collection.exists(object [, options])
The exists()
method determines whether a document exists given an object
object
containing the _id
or _key
attribute. If both attributes
are given, the _id
takes precedence, it is an error, if the collection
part of the _id
does not match the collection
.
An error is thrown if _rev
is specified but the document found has a
different revision already.
Instead of returning the found document or an error, this method will
only return an object with the attributes _id
, _key
and _rev
, or
false
if no document with the given _id
or _key
exists. It can
thus be used for easy existence checks.
This method throws an error if used improperly, e.g. if called
with a string that isn’t a document key or identifier, an object with invalid
or missing _key
or _id
attribute, or if documents from other collections are
requested.
If you pass options
as the second argument, it must be an object. If this
object has the allowDirtyReads
attribute set to true
, then the
Coordinator is allowed to read from any shard replica and not only from
the leader shard. See Read from followers
for details.
collection.exists(document-identifier [, options])
Checks whether a document exists described by a document identifier, optionally with options passed as an object.
No revision can be specified in this case.
collection.exists(document-key [, options])
Checks whether a document exists described by a document key, optionally with options passed as an object.
No revision can be specified in this case.
collection.exists(array [, options])
This variant allows you to perform the operation on a whole array of arguments.
The behavior is exactly as if exists()
would have been called on all
members of the array separately and all results are returned in an array. If an error
occurs with any of the documents, the operation stops immediately returning
only an error object.
collection.firstExample(example)
Returns some document of a collection that matches the specified
example. If no such document exists, null
will be returned.
The example has to be specified as paths and values.
See byExample
for details.
collection.firstExample(path1, value1, ...)
As alternative you can supply an array of paths and values.
Examples
db.users.firstExample("name", "Angela");
collection.insert(data [, options])
Creates a new document in the collection
from the given data
. The
data
must be an object. The attributes _id
and _rev
are ignored
and are automatically generated. A unique value for the attribute _key
will be automatically generated if not specified. If specified, there
must not be a document with the given _key
in the collection.
The method returns a document with the attributes _id
, _key
and
_rev
. The attribute _id
contains the document identifier of the newly
created document, the attribute _key
the document key and the
attribute _rev
contains the document revision.
collection.insert(data, options)
Creates a new document in the collection
from the given data
as
above. The optional options
parameter must be an object and can be
used to specify the following options:
waitForSync
: One can force synchronization of the document creation operation to disk even in case that thewaitForSync
flag is been disabled for the entire collection. Thus, thewaitForSync
option can be used to force synchronization of just specific operations. To use this, set thewaitForSync
parameter totrue
. If thewaitForSync
parameter is not specified or set tofalse
, then the collection’s defaultwaitForSync
behavior is applied. ThewaitForSync
parameter cannot be used to disable synchronization for collections that have a defaultwaitForSync
value oftrue
.silent
: If this flag is set totrue
, the method does not return any output.returnNew
: If this flag is set totrue
, the complete new document is returned in the output under the attributenew
.returnOld
: If this flag is set totrue
, the complete old document is returned in the output under the attributeold
. Only available in combination with theoverwrite
optionoverwrite
: If set totrue
, the insert becomes a replace-insert. If a document with the same_key
exists already the new document is not rejected with unique constraint violated but will replace the old document. Note that operations withoverwrite
parameter require a_key
attribute in the request payload, therefore they can only be performed on collections sharded by_key
.overwriteMode
: this optional flag can have one of the following values:ignore
: if a document with the specified_key
value exists already, nothing will be done and no write operation will be carried out. The insert operation will return success in this case. This mode does not support returning the old document version using thereturnOld
attribute.returnNew
will only set thenew
attribute in the response if a new document was inserted.replace
: if a document with the specified_key
value exists already, it will be overwritten with the specified document value. This mode will also be used when no overwrite mode is specified but theoverwrite
flag is set totrue
.update
: if a document with the specified_key
value exists already, it will be patched (partially updated) with the specified document value. The overwrite mode can be further controlled via thekeepNull
andmergeObjects
parameters.conflict
: if a document with the specified_key
value exists already, return a unique constraint violation error so that the insert operation fails. This is also the default behavior in case the overwrite mode is not set, and theoverwrite
flag isfalse
or not set either.
keepNull
: The optionalkeepNull
parameter can be used to modify the behavior when handlingnull
values. Normally,null
values are stored in the database. By setting thekeepNull
parameter tofalse
, this behavior can be changed so that top-level attributes and sub-attributes indata
withnull
values are removed from the target document (but not attributes of objects that are nested inside of arrays). This option controls the update-insert behavior only.mergeObjects
: Controls whether objects (not arrays) will be merged if present in both the existing and the patch document. If set tofalse
, the value in the patch document will overwrite the existing document’s value. If set totrue
, objects will be merged. The default istrue
. This option controls the update-insert behavior only.versionAttribute
: Only applicable ifoverwrite
is set totrue
oroverwriteMode
is set toupdate
orreplace
.You can use the
versionAttribute
option for external versioning support. If set, the attribute with the name specified by the option is looked up in the stored document and the attribute value is compared numerically to the value of the versioning attribute in the supplied document that is supposed to update/replace it.If the version number in the new document is higher (rounded down to a whole number) than in the document that already exists in the database, then the update/replace operation is performed normally. This is also the case if the new versioning attribute has a non-numeric value, if it is a negative number, or if the attribute doesn’t exist in the supplied or stored document.
If the version number in the new document is lower or equal to what exists in the database, the operation is not performed and the existing document thus not changed. No error is returned in this case.
The attribute can only be a top-level attribute.
You can check if
_oldRev
(if present) and_rev
are different to determine if the document has been changed.
collection.insert(array [, options])
This variant allows you to perform the operation on a whole array of
arguments. The behavior is exactly as if insert()
would have been called on all
members of the array separately and all results are returned in an array. If an
error occurs with any of the documents, no exception is raised! Instead of a
document, an error object is returned in the result array.
Examples
db.example.insert({ Hello : "World" });
db.example.insert({ Hello : "World" }, {waitForSync: true});
db.example.insert([{ Hello : "World" }, {Hello: "there"}])
db.example.insert([{ Hello : "World" }, {}], {waitForSync: true});
db.example.insert({ _key : "666", Hello : "World" });
db.example.insert({ _key : "666", Hello : "Universe" }, {overwrite: true, returnOld: true});
collection.iterate(iterator [, options])
iterate()
method is deprecated from version 3.11.0 onwards and will be
removed in a future version.Iterates over some elements of the collection and apply the function
iterator
to the elements. The function will be called with the
document as first argument and the current number (starting with 0)
as second argument.
options
must be an object with the following attributes:
limit
(optional, default none): use at mostlimit
documents.probability
(optional, default all): a number between0
and1
. Documents are chosen with this probability.
Examples
Pick 1 out of 4 documents of a collection but at most 5:
var arr = [];
for (var i = 0; i < 10; i++) {
arr.push({ i });
}
var meta = db.example.save(arr);
var data = [];
db.example.iterate( (doc, idx) => data.push({ idx, i: doc.i }), { probability: 0.25, limit: 5 });
data;
collection.remove(object)
Removes a document described by the object
, which must be an object
containing the _id
or _key
attribute. There must be a document with
that _id
or _key
in the current collection. This document is then
removed.
The method returns a document with the attributes _id
, _key
and _rev
.
The attribute _id
contains the document identifier of the
removed document, the attribute _rev
contains the document revision of
the removed document.
If the object contains a _rev
attribute, the method first checks
that the specified revision is the current revision of that document.
If not, there is a conflict, and an error is thrown.
collection.remove(object, options)
Removes a document, with additional boolean options
passed as an object:
waitForSync
: One can force synchronization of the document creation operation to disk even in case that thewaitForSync
flag is been disabled for the entire collection. Thus, thewaitForSync
option can be used to force synchronization of just specific operations. To use this, set thewaitForSync
parameter totrue
. If thewaitForSync
parameter is not specified or set tofalse
, then the collection’s defaultwaitForSync
behavior is applied. ThewaitForSync
parameter cannot be used to disable synchronization for collections that have a defaultwaitForSync
value oftrue
.overwrite
: If this flag is set totrue
, a_rev
attribute in the object is ignored.returnOld
: If this flag is set totrue
, the complete previous revision of the document is returned in the output under the attributeold
.silent
: If this flag is set totrue
, no output is returned.
collection.remove(document-identifier [, options])
Removes a document described by a document identifier, optionally with additional options passed as an object.
No revision check is performed.
collection.remove(document-key [, options])
Removes a document described by a document key, optionally with additional options passed as an object.
No revision check is performed.
collection.remove(array [, options])
This variant allows you to perform the operation on a whole array of
document identifiers, document keys, and objects with a _key
attribute.
The behavior is exactly as if remove()
would have been called on all
members of the array separately and all results are returned in an array. If an
error occurs with any of the documents, no exception is raised! Instead of a
document, an error object is returned in the result array.
Examples
Remove a document:
a1 = db.example.insert({ a : 1 });
db.example.document(a1);
db.example.remove(a1);
db.example.document(a1);
Remove a document with a conflict:
a1 = db.example.insert({ a : 1 });
a2 = db.example.replace(a1, { a : 2 });
db.example.remove(a1);
db.example.remove(a1, true);
db.example.document(a1);
collection.removeByExample(example)
Removes all documents matching an example.
collection.removeByExample(document, waitForSync)
The optional waitForSync
parameter can be used to force synchronization
of the document deletion operation to disk even in case that the
waitForSync
flag had been disabled for the entire collection. Thus,
the waitForSync
parameter can be used to force synchronization of just
specific operations. To use this, set the waitForSync
parameter to
true
. If the waitForSync
parameter is not specified or set to
false
, then the collection’s default waitForSync
behavior is
applied. The waitForSync
parameter cannot be used to disable
synchronization for collections that have a default waitForSync
value
of true
.
collection.removeByExample(document, waitForSync, limit)
The optional limit
parameter can be used to restrict the number of
removals to the specified value. If limit
is specified but less than the
number of documents in the collection, it is undefined which documents are
removed.
Examples
db.example.removeByExample( {Hello : "world"} );
collection.removeByKeys(keys)
Looks up the documents in the specified collection using the array of keys
provided, and removes all documents from the collection whose keys are
contained in the keys
array. Keys for which no document can be found in
the underlying collection are ignored, and no exception will be thrown for
them.
The method will return an object containing the number of removed documents
in the removed
sub-attribute, and the number of not-removed/ignored
documents in the ignored
sub-attribute.
This method is deprecated in favor of the array variant of remove()
.
Examples
var keys = [ ];
for (var i = 0; i < 5; ++i) {
db.example.insert({ _key: "test" + i, value: i });
keys.push("test" + i);
}
db.example.removeByKeys(keys);
collection.replace(document, data [, options])
collection.replace(object, data)
Replaces an existing document described by the object
, which must
be an object containing the _id
or _key
attribute. There must be
a document with that _id
or _key
in the current collection. This
document is then replaced with the data
given as second argument.
Any attribute _id
, _key
or _rev
in data
is ignored.
The method returns a document with the attributes _id
, _key
, _rev
and _oldRev
. The attribute _id
contains the document identifier of the
updated document, the attribute _rev
contains the document revision of
the updated document, the attribute _oldRev
contains the revision of
the old (now replaced) document.
If the object contains a _rev
attribute, the method first checks
that the specified revision is the current revision of that document.
If not, there is a conflict, and an error is thrown.
collection.replace(object, data, options)
Replaces an existing document, with additional options passed as an object:
waitForSync
: One can force synchronization of the document creation operation to disk even in case that thewaitForSync
flag is been disabled for the entire collection. Thus, thewaitForSync
option can be used to force synchronization of just specific operations. To use this, set thewaitForSync
parameter totrue
. If thewaitForSync
parameter is not specified or set tofalse
, then the collection’s defaultwaitForSync
behavior is applied. ThewaitForSync
parameter cannot be used to disable synchronization for collections that have a defaultwaitForSync
value oftrue
.overwrite
: If this flag is set totrue
, a_rev
attribute in the object is ignored.returnNew
: If this flag is set totrue
, the complete new document is returned in the output under the attributenew
.returnOld
: If this flag is set totrue
, the complete previous revision of the document is returned in the output under the attributeold
.silent
: If this flag is set totrue
, no output is returned.versionAttribute
: You can use theversionAttribute
option for external versioning support. If set, the attribute with the name specified by the option is looked up in the stored document and the attribute value is compared numerically to the value of the versioning attribute in the supplied document that is supposed to replace it.If the version number in the new document is higher (rounded down to a whole number) than in the document that already exists in the database, then the replace operation is performed normally. This is also the case if the new versioning attribute has a non-numeric value, if it is a negative number, or if the attribute doesn’t exist in the supplied or stored document.
If the version number in the new document is lower or equal to what exists in the database, the operation is not performed and the existing document thus not changed. No error is returned in this case.
The attribute can only be a top-level attribute.
You can check if
_oldRev
and_rev
are different to determine if the document has been changed.
collection.replace(document-identifier, data [, options])
Replaces an existing document described by a document identifier, optionally with additional options passed as an object.
No revision check is performed.
collection.replace(document-key, data [, options])
Replaces an existing document described by a document key, optionally with additional options passed as an object.
No revision check is performed.
collection.replace(document-array, data-array [, options])
This variant allows you to perform the replace operation on two whole arrays of
arguments. The two arrays given as document-array
and data-array
must have the same length. The behavior is exactly as if replace()
would have
been called on all respective members of the two arrays in pairs and all results
are returned in an array. If an error occurs with any of the documents, no
exception is raised! Instead of a document, an error object is returned in the
result array.
Examples
Create and update a document:
a1 = db.example.insert({ a : 1 });
a2 = db.example.replace(a1, { a : 2 });
a3 = db.example.replace(a1, { a : 3 });
a3 = db.example.replace(a1, { a : 3 }, { overwrite: true });
Use a document identifier:
a1 = db.example.insert({ a : 1 });
a2 = db.example.replace("example/3903044", { a : 2 });
collection.replaceByExample(example, newValue [, waitForSync [, limit]])
Replaces all documents matching an example with a new document body.
The entire document body of each document matching the example
is
replaced with newValue
. The document meta-attributes _id
, _key
and
_rev
are not replaced.
The optional waitForSync
parameter can be used to force synchronization
of the document replacement operation to disk even in case that the
waitForSync
flag had been disabled for the entire collection. Thus,
the waitForSync
parameter can be used to force synchronization of just
specific operations. To use this, set the waitForSync
parameter to
true
. If the waitForSync
parameter is not specified or set to
false
, then the collection’s default waitForSync
behavior is
applied. The waitForSync
parameter cannot be used to disable
synchronization for collections that have a default waitForSync
value
of true
.
The optional limit
parameter can be used to restrict the number of
replacements to the specified value. If limit
is specified but less than
the number of documents in the collection, it is undefined which documents are
replaced.
Examples
db.example.insert({ Hello : "world" });
db.example.replaceByExample({ Hello: "world" }, {Hello: "mars"}, false, 5);
collection.save(data [, options])
See collection.insert(data [, options])
.
collection.toArray()
Converts the entire collection into an array of documents.
collection.update(document, data [, options])
collection.update(object, data)
Updates an existing document described by the object
, which must
be an object containing the _id
or _key
attribute. There must be
a document with that _id
or _key
in the current collection. This
document is then patched with the data
given as second argument.
Any attribute _id
, _key
or _rev
in data
is ignored.
The method returns a document with the attributes _id
, _key
, _rev
and _oldRev
.
- The
_key
and_id
attributes contains the document key and document identifier of the updated document. - The
_rev
attribute contains the document revision of the updated document - The
_oldRev
attribute contains the revision of the old (now updated) document.
If the object contains a _rev
attribute, the method first checks
that the specified revision is the current revision of that document.
If not, there is a conflict, and an error is raised.
collection.update(object, data, options)
Updates an existing document, with additional options passed as an object:
waitForSync
: One can force synchronization of the document creation operation to disk even in case that thewaitForSync
flag is been disabled for the entire collection. Thus, thewaitForSync
option can be used to force synchronization of just specific operations. To use this, set thewaitForSync
parameter totrue
. If thewaitForSync
parameter is not specified or set tofalse
, then the collection’s defaultwaitForSync
behavior is applied. ThewaitForSync
parameter cannot be used to disable synchronization for collections that have a defaultwaitForSync
value oftrue
.overwrite
: If this flag is set totrue
, a_rev
attribute in the selector is ignored.returnNew
: If this flag is set totrue
, the complete new document is returned in the output under the attributenew
.returnOld
: If this flag is set totrue
, the complete previous revision of the document is returned in the output under the attributeold
.silent
: If this flag is set totrue
, no output is returned.keepNull
: The optionalkeepNull
parameter can be used to modify the behavior when handlingnull
values. Normally,null
values are stored in the database. By setting thekeepNull
parameter tofalse
, this behavior can be changed so that top-level attributes and sub-attributes indata
withnull
values are removed from the target document (but not attributes of objects that are nested inside of arrays).mergeObjects
: Controls whether objects (not arrays) will be merged if present in both the existing and the patch document. If set tofalse
, the value in the patch document will overwrite the existing document’s value. If set totrue
, objects will be merged. The default istrue
.versionAttribute
: You can use theversionAttribute
option for external versioning support. If set, the attribute with the name specified by the option is looked up in the stored document and the attribute value is compared numerically to the value of the versioning attribute in the supplied document that is supposed to update it.If the version number in the new document is higher (rounded down to a whole number) than in the document that already exists in the database, then the update operation is performed normally. This is also the case if the new versioning attribute has a non-numeric value, if it is a negative number, or if the attribute doesn’t exist in the supplied or stored document.
If the version number in the new document is lower or equal to what exists in the database, the operation is not performed and the existing document thus not changed. No error is returned in this case.
The attribute can only be a top-level attribute.
You can check if
_oldRev
and_rev
are different to determine if the document has been changed.
collection.update(document-identifier, data [, options])
Updates an existing document described by a document identifier, optionally with additional options passed as an object.
No revision check is performed.
collection.update(document-key, data [, options])
Updates an existing document described by a document key, optionally with additional options passed as an object.
No revision check is performed.
collection.update(document-array, data-array [, options])
This variant allows you to perform the operation on two whole arrays of
arguments. The two arrays given as document-array
and data-array
must have the same length. The behavior is exactly as if update()
would have
been called on all respective members of the two arrays in pairs and all results are
returned in an array. If an error occurs with any of the documents, no
exception is raised! Instead of a document, an error object is returned in the
result array.
Examples
Create and update a document:
a1 = db.example.insert({"a" : 1});
a2 = db.example.update(a1, {"b" : 2, "c" : 3});
a3 = db.example.update(a1, {"d" : 4});
a4 = db.example.update(a2, {"e" : 5, "f" : 6 });
db.example.document(a4);
a5 = db.example.update(a4, {"a" : 1, c : 9, e : 42 });
db.example.document(a5);
Use a document identifier:
a1 = db.example.insert({"a" : 1});
a2 = db.example.update("example/18612115", { "x" : 1, "y" : 2 });
Use the keepNull
parameter to remove attributes with null
values:
db.example.insert({"a" : 1});
db.example.update("example/19988371", { "b" : null, "c" : null, "d" : 3 });
db.example.document("example/19988371");
db.example.update("example/19988371", { "a" : null }, false, false);
db.example.document("example/19988371");
db.example.update("example/19988371", { "b" : null, "c": null, "d" : null }, false, false);
db.example.document("example/19988371");
Patching array values:
db.example.insert({
"a" : { "one" : 1, "two" : 2, "three" : 3 },
"b" : { }
});
db.example.update("example/20774803", {
"a" : { "four" : 4 },
"b" : { "b1" : 1 }
});
db.example.document("example/20774803");
db.example.update("example/20774803", {
"a" : { "one" : null },
"b" : null
}, false, false);
db.example.document("example/20774803");
collection.updateByExample(example, newValue [, options])
collection.updateByExample(example, newValue [, keepNull [, waitForSync [, limit]]])
Updates all documents matching an example with a new document body.
Specific attributes in the document body of each document matching the
example
are updated with the values from newValue
.
The document meta-attributes _id
, _key
and _rev
cannot be updated.
The optional keepNull
parameter can be used to modify the behavior when
handling null
values. Normally, null
values are stored in the
database. By setting the keepNull
parameter to false
, this behavior
can be changed so that top-level attributes and sub-attributes in data
with
null
values are removed from the target document (but not attributes of
objects that are nested inside of arrays).
The optional waitForSync
parameter can be used to force synchronization
of the document replacement operation to disk even in case that the
waitForSync
flag had been disabled for the entire collection. Thus,
the waitForSync
parameter can be used to force synchronization of just
specific operations. To use this, set the waitForSync
parameter to
true
. If the waitForSync
parameter is not specified or set to
false
, then the collection’s default waitForSync
behavior is
applied. The waitForSync
parameter cannot be used to disable
synchronization for collections that have a default waitForSync
value
of true
.
The optional limit
parameter can be used to restrict the number of
updates to the specified value. If limit
is specified but less than
the number of documents in the collection, it is undefined which documents are
updated.
collection.updateByExample(document, newValue, options)
Using this variant, the options for the operation can be passed using an object with the following sub-attributes:
keepNull
waitForSync
limit
mergeObjects
Examples
db.example.insert({ Hello : "world", foo : "bar" });
db.example.updateByExample({ Hello: "world" }, { Hello: "foo", World: "bar" }, false);
db.example.byExample({ Hello: "foo" }).toArray()
Edge documents
edge-collection.edges(vertex)
Edges are normal documents that always contain a _from
and a _to
attribute. Therefore, you can use the document methods to operate on
edges. The following methods, however, are specific to edges.
edge-collection.edges(vertex)
The edges()
operator finds all edges starting from (outbound) or ending
in (inbound) vertex
.
edge-collection.edges(vertices)
The edges
operator finds all edges starting from (outbound) or ending
in (inbound) a document from vertices
, which must be a list of documents
or document identifiers.
var vcoll = db._create("vertex");
var ecoll = db._createEdgeCollection("relation");
var myGraph = {};
myGraph.v1 = db.vertex.insert({ name : "vertex 1" });
myGraph.v2 = db.vertex.insert({ name : "vertex 2" });
myGraph.e1 = db.relation.insert(myGraph.v1, myGraph.v2, { label : "knows"});
db._document(myGraph.e1);
db.relation.edges(myGraph.e1._id);
edge-collection.inEdges(vertex)
The inEdges()
operator finds all edges ending in (inbound) vertex
.
edge-collection.inEdges(vertices)
The inEdges()
operator finds all edges ending in (inbound) a document from
vertices
, which must be a list of documents or document identifiers.
Examples
var vcoll = db._create("vertex");
var ecoll = db._createEdgeCollection("relation");
var myGraph = {};
myGraph.v1 = db.vertex.insert({ name : "vertex 1" });
myGraph.v2 = db.vertex.insert({ name : "vertex 2" });
myGraph.e1 = db.relation.insert(myGraph.v1, myGraph.v2, { label : "knows"});
db._document(myGraph.e1);
db.relation.inEdges(myGraph.v1._id);
db.relation.inEdges(myGraph.v2._id);
edge-collection.outEdges(vertex)
The outEdges()
operator finds all edges starting from (outbound)
vertices
.
edge-collection.outEdges(vertices)
The outEdges()
operator finds all edges starting from (outbound) a document
from vertices
, which must be a list of documents or document identifiers.
Examples
var vcoll = db._create("vertex");
var ecoll = db._createEdgeCollection("relation");
var myGraph = {};
myGraph.v1 = db.vertex.insert({ name : "vertex 1" });
myGraph.v2 = db.vertex.insert({ name : "vertex 2" });
myGraph.e1 = db.relation.insert(myGraph.v1, myGraph.v2, { label : "knows"});
db._document(myGraph.e1);
db.relation.outEdges(myGraph.v1._id);
db.relation.outEdges(myGraph.v2._id);