Interface DocumentCollection<EntryResultType, EntryInputType>

Represents an document collection in a databases.Database.

See EdgeCollection for a variant of this interface more suited for edge collections.

When using TypeScript, collections can be cast to a specific document data type to increase type safety.

Example

interface Person {
name: string;
}
const db = new Database();
const documents = db.collection("persons") as DocumentCollection<Person>;
interface DocumentCollection<EntryResultType, EntryInputType> {
    database: Database;
    name: string;
    checksum(options?): Promise<ArangoApiResponse<CollectionDescription & {
        checksum: string;
        revision: string;
    }>>;
    compact(): Promise<ArangoApiResponse<CollectionDescription>>;
    count(): Promise<ArangoApiResponse<CollectionDescription & CollectionProperties & {
        count: number;
    }>>;
    create(options?): Promise<ArangoApiResponse<CollectionDescription & CollectionProperties>>;
    document(selector, options?): Promise<Document<EntryResultType>>;
    document(selector, graceful): Promise<Document<EntryResultType>>;
    documentExists(selector, options?): Promise<boolean>;
    documentId(selector): string;
    documents(selectors, options?): Promise<Document<EntryResultType>[]>;
    drop(options?): Promise<ArangoApiResponse<{
        id: string;
    }>>;
    dropIndex(selector): Promise<ArangoApiResponse<{
        id: string;
    }>>;
    ensureIndex(options): Promise<ArangoApiResponse<{
        fields: string[];
        figures?: Record<string, any>;
        id: string;
        name: string;
        sparse: boolean;
        type: "persistent";
        unique: boolean;
    } & {
        cacheEnabled: boolean;
        deduplicate: boolean;
        estimates: boolean;
        selectivityEstimate: number;
        storedValues?: string[];
    } & {
        isNewlyCreated: boolean;
    }>>;
    ensureIndex(options): Promise<ArangoApiResponse<{
        fields: [string];
        figures?: Record<string, any>;
        id: string;
        name: string;
        sparse: boolean;
        type: "ttl";
        unique: boolean;
    } & {
        estimates: boolean;
        expireAfter: number;
        selectivityEstimate: number;
    } & {
        isNewlyCreated: boolean;
    }>>;
    ensureIndex(options): Promise<ArangoApiResponse<{
        fields: string[];
        figures?: Record<string, any>;
        id: string;
        name: string;
        sparse: boolean;
        type: "mdi";
        unique: boolean;
    } & {
        estimates: boolean;
        fieldValueTypes: "double";
        selectivityEstimate: number;
        storedValues?: string[];
    } & {
        isNewlyCreated: boolean;
    }>>;
    ensureIndex(options): Promise<ArangoApiResponse<{
        fields: string[];
        figures?: Record<string, any>;
        id: string;
        name: string;
        sparse: boolean;
        type: "mdi-prefixed";
        unique: boolean;
    } & {
        estimates: boolean;
        fieldValueTypes: "double";
        prefixFields: string[];
        selectivityEstimate: number;
        storedValues?: string[];
    } & {
        isNewlyCreated: boolean;
    }>>;
    ensureIndex(details): Promise<ArangoApiResponse<{
        fields: string[];
        figures?: Record<string, any>;
        id: string;
        name: string;
        sparse: boolean;
        type: "mdi-prefixed";
        unique: boolean;
    } & {
        estimates: boolean;
        fieldValueTypes: "double";
        prefixFields: string[];
        selectivityEstimate: number;
        storedValues?: string[];
    } & {
        isNewlyCreated: boolean;
    }>>;
    ensureIndex(options): Promise<ArangoApiResponse<{
        fields: [string] | [string, string];
        figures?: Record<string, any>;
        id: string;
        name: string;
        sparse: boolean;
        type: "geo";
        unique: boolean;
    } & {
        bestIndexedLevel: number;
        geoJson: boolean;
        legacyPolygons: boolean;
        maxNumCoverCells: number;
        worstIndexedLevel: number;
    } & {
        isNewlyCreated: boolean;
    }>>;
    ensureIndex(options): Promise<ArangoApiResponse<{
        fields: InvertedIndexField[];
        figures?: Record<string, any>;
        id: string;
        name: string;
        sparse: boolean;
        type: "inverted";
        unique: boolean;
    } & {
        analyzer: string;
        cache?: boolean;
        cleanupIntervalStep: number;
        commitIntervalMsec: number;
        consolidationIntervalMsec: number;
        consolidationPolicy: Required<TierConsolidationPolicy>;
        features: AnalyzerFeature[];
        includeAllFields: boolean;
        optimizeTopK: string[];
        parallelism: number;
        primaryKeyCache?: boolean;
        primarySort: {
            cache?: boolean;
            compression: Compression;
            fields: {
                direction: Direction;
                field: string;
            }[];
        };
        searchField: boolean;
        storedValues: {
            cache?: boolean;
            compression: Compression;
            fields: string[];
        }[];
        trackListPositions: boolean;
        writeBufferActive: number;
        writeBufferIdle: number;
        writeBufferSizeMax: number;
    } & {
        isNewlyCreated: boolean;
    }>>;
    ensureIndex(options): Promise<ArangoApiResponse<IndexDescription & {
        isNewlyCreated: boolean;
    }>>;
    exists(): Promise<boolean>;
    figures(details?): Promise<ArangoApiResponse<CollectionDescription & CollectionProperties & {
        count: number;
        figures: Record<string, any>;
    }>>;
    get(): Promise<ArangoApiResponse<CollectionDescription>>;
    getResponsibleShard(document): Promise<string>;
    import(data, options?): Promise<ImportDocumentsResult>;
    import(data, options?): Promise<ImportDocumentsResult>;
    import(data, options?): Promise<ImportDocumentsResult>;
    index(selector): Promise<IndexDescription>;
    indexes<IndexType>(options?): Promise<IndexType[]>;
    loadIndexes(): Promise<boolean>;
    properties(): Promise<ArangoApiResponse<CollectionDescription & CollectionProperties>>;
    properties(properties): Promise<ArangoApiResponse<CollectionDescription & CollectionProperties>>;
    recalculateCount(): Promise<boolean>;
    remove(selector, options?): Promise<DocumentMetadata & {
        old?: Document<EntryResultType>;
    }>;
    removeAll(selectors, options?): Promise<(DocumentOperationFailure | DocumentMetadata & {
        old?: Document<EntryResultType>;
    })[]>;
    rename(newName): Promise<ArangoApiResponse<CollectionDescription>>;
    replace(selector, newData, options?): Promise<DocumentMetadata & {
        _oldRev?: string;
    } & {
        new?: Document<EntryResultType>;
        old?: Document<EntryResultType>;
    }>;
    replaceAll(newData, options?): Promise<(DocumentOperationFailure | DocumentMetadata & {
        _oldRev?: string;
    } & {
        new?: Document<EntryResultType>;
        old?: Document<EntryResultType>;
    })[]>;
    revision(): Promise<ArangoApiResponse<CollectionDescription & CollectionProperties & {
        revision: string;
    }>>;
    save(data, options?): Promise<DocumentMetadata & {
        _oldRev?: string;
    } & {
        new?: Document<EntryResultType>;
        old?: Document<EntryResultType>;
    }>;
    saveAll(data, options?): Promise<(DocumentOperationFailure | DocumentMetadata & {
        _oldRev?: string;
    } & {
        new?: Document<EntryResultType>;
        old?: Document<EntryResultType>;
    })[]>;
    shards(details?): Promise<ArangoApiResponse<CollectionDescription & CollectionProperties & {
        shards: string[];
    }>>;
    shards(details): Promise<ArangoApiResponse<CollectionDescription & CollectionProperties & {
        shards: Record<string, string[]>;
    }>>;
    shards(details?): Promise<ArangoApiResponse<CollectionDescription & CollectionProperties & {
        shards: string[];
    }>>;
    shards(details): Promise<ArangoApiResponse<CollectionDescription & CollectionProperties & {
        shards: Record<string, string[]>;
    }>>;
    truncate(options?): Promise<ArangoApiResponse<CollectionDescription>>;
    update(selector, newData, options?): Promise<DocumentMetadata & {
        _oldRev?: string;
    } & {
        new?: Document<EntryResultType>;
        old?: Document<EntryResultType>;
    }>;
    updateAll(newData, options?): Promise<(DocumentOperationFailure | DocumentMetadata & {
        _oldRev?: string;
    } & {
        new?: Document<EntryResultType>;
        old?: Document<EntryResultType>;
    })[]>;
}

Type Parameters

  • EntryResultType extends Record<string, any> = any

    Type to represent document contents returned by the server (including computed properties).

  • EntryInputType extends Record<string, any> = EntryResultType

    Type to represent document contents passed when inserting or replacing documents (without computed properties).

Hierarchy (view full)

Properties

database: Database

Database this collection belongs to.

name: string

Name of the collection.

Methods

  • Creates a collection with the given options and the instance's name.

    See also databases.Database#createCollection and databases.Database#createEdgeCollection.

    Note: When called on an EdgeCollection instance in TypeScript, the type option must still be set to the correct CollectionType. Otherwise this will result in the collection being created with the default type (i.e. as a document collection).

    Parameters

    • Optional options: CollectionPropertiesOptions & {
          distributeShardsLike?: string;
          enforceReplicationFactor?: boolean;
          keyOptions?: CollectionKeyOptions;
          numberOfShards?: number;
          shardKeys?: string[];
          shardingStrategy?: ShardingStrategy;
          smartGraphAttribute?: string;
          smartJoinAttribute?: string;
          waitForSyncReplication?: boolean;
      } & {
          type?: CollectionType;
      }

      Options for creating the collection.

    Returns Promise<ArangoApiResponse<CollectionDescription & CollectionProperties>>

    Example

    const db = new Database();
    const collection = db.collection("potatoes");
    await collection.create();
    // the document collection "potatoes" now exists

    Example

    const db = new Database();
    const collection = db.collection("friends");
    await collection.create({ type: CollectionType.EDGE_COLLECTION });
    // the edge collection "friends" now exists

    Example

    interface Friend {
    startDate: number;
    endDate?: number;
    }
    const db = new Database();
    const collection = db.collection("friends") as EdgeCollection<Friend>;
    // even in TypeScript you still need to indicate the collection type
    // if you want to create an edge collection
    await collection.create({ type: CollectionType.EDGE_COLLECTION });
    // the edge collection "friends" now exists
  • Retrieves the document matching the given key or id.

    Throws an exception when passed a document or _id from a different collection.

    Parameters

    • selector: DocumentSelector

      Document _key, _id or object with either of those properties (e.g. a document from this collection).

    • Optional options: ReadDocumentOptions

      Options for retrieving the document.

    Returns Promise<Document<EntryResultType>>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    try {
    const document = await collection.document("abc123");
    console.log(document);
    } catch (e: any) {
    console.error("Could not find document");
    }

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    const document = await collection.document("abc123", { graceful: true });
    if (document) {
    console.log(document);
    } else {
    console.error("Could not find document");
    }
  • Retrieves the document matching the given key or id.

    Throws an exception when passed a document or _id from a different collection.

    Parameters

    • selector: DocumentSelector

      Document _key, _id or object with either of those properties (e.g. a document from this collection).

    • graceful: boolean

      If set to true, null is returned instead of an exception being thrown if the document does not exist.

    Returns Promise<Document<EntryResultType>>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    try {
    const document = await collection.document("abc123", false);
    console.log(document);
    } catch (e: any) {
    console.error("Could not find document");
    }

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    const document = await collection.document("abc123", true);
    if (document) {
    console.log(document);
    } else {
    console.error("Could not find document");
    }
  • Checks whether a document matching the given key or id exists in this collection.

    Throws an exception when passed a document or _id from a different collection.

    Parameters

    Returns Promise<boolean>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    const exists = await collection.documentExists("abc123");
    if (!exists) {
    console.log("Document does not exist");
    }
  • Derives a document _id from the given selector for this collection.

    Throws an exception when passed a document or _id from a different collection.

    Parameters

    • selector: DocumentSelector

      Document _key, _id or object with either of those properties (e.g. a document from this collection).

    Returns string

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    const meta = await collection.save({ foo: "bar" }, { returnNew: true });
    const doc = meta.new;
    console.log(collection.documentId(meta)); // via meta._id
    console.log(collection.documentId(doc)); // via doc._id
    console.log(collection.documentId(meta._key)); // also works

    Example

    const db = new Database();
    const collection1 = db.collection("some-collection");
    const collection2 = db.collection("other-collection");
    const meta = await collection1.save({ foo: "bar" });
    // Mixing collections is usually a mistake
    console.log(collection1.documentId(meta)); // ok: same collection
    console.log(collection2.documentId(meta)); // throws: wrong collection
    console.log(collection2.documentId(meta._id)); // also throws
    console.log(collection2.documentId(meta._key)); // ok but wrong collection
  • Retrieves the documents matching the given key or id values.

    Throws an exception when passed a document or _id from a different collection, or if the document does not exist.

    Parameters

    • selectors: (string | ObjectWithDocumentKey)[]

      Array of document _key, _id or objects with either of those properties (e.g. a document from this collection).

    • Optional options: BulkReadDocumentsOptions

      Options for retrieving the documents.

    Returns Promise<Document<EntryResultType>[]>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    try {
    const documents = await collection.documents(["abc123", "xyz456"]);
    console.log(documents);
    } catch (e: any) {
    console.error("Could not find document");
    }
  • Deletes the collection from the database.

    Parameters

    Returns Promise<ArangoApiResponse<{
        id: string;
    }>>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    await collection.drop();
    // The collection "some-collection" is now an ex-collection
  • Deletes the index with the given name or id from the database.

    Parameters

    • selector: IndexSelector

      Index name, id or object with either property.

    Returns Promise<ArangoApiResponse<{
        id: string;
    }>>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    await collection.dropIndex("some-index");
    // The index "some-index" no longer exists
  • Creates a persistent index on the collection if it does not already exist.

    Parameters

    Returns Promise<ArangoApiResponse<{
        fields: string[];
        figures?: Record<string, any>;
        id: string;
        name: string;
        sparse: boolean;
        type: "persistent";
        unique: boolean;
    } & {
        cacheEnabled: boolean;
        deduplicate: boolean;
        estimates: boolean;
        selectivityEstimate: number;
        storedValues?: string[];
    } & {
        isNewlyCreated: boolean;
    }>>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    // Create a unique index for looking up documents by username
    await collection.ensureIndex({
    type: "persistent",
    fields: ["username"],
    name: "unique-usernames",
    unique: true
    });
  • Creates a TTL index on the collection if it does not already exist.

    Parameters

    Returns Promise<ArangoApiResponse<{
        fields: [string];
        figures?: Record<string, any>;
        id: string;
        name: string;
        sparse: boolean;
        type: "ttl";
        unique: boolean;
    } & {
        estimates: boolean;
        expireAfter: number;
        selectivityEstimate: number;
    } & {
        isNewlyCreated: boolean;
    }>>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    // Expire documents with "createdAt" timestamp one day after creation
    await collection.ensureIndex({
    type: "ttl",
    fields: ["createdAt"],
    expireAfter: 60 * 60 * 24 // 24 hours
    });

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    // Expire documents with "expiresAt" timestamp according to their value
    await collection.ensureIndex({
    type: "ttl",
    fields: ["expiresAt"],
    expireAfter: 0 // when attribute value is exceeded
    });
  • Creates a multi-dimensional index on the collection if it does not already exist.

    Parameters

    Returns Promise<ArangoApiResponse<{
        fields: string[];
        figures?: Record<string, any>;
        id: string;
        name: string;
        sparse: boolean;
        type: "mdi";
        unique: boolean;
    } & {
        estimates: boolean;
        fieldValueTypes: "double";
        selectivityEstimate: number;
        storedValues?: string[];
    } & {
        isNewlyCreated: boolean;
    }>>

    Example

    const db = new Database();
    const collection = db.collection("some-points");
    // Create a multi-dimensional index for the attributes x, y and z
    await collection.ensureIndex({
    type: "mdi",
    fields: ["x", "y", "z"],
    fieldValueTypes: "double"
    });
    
    
  • Creates a prefixed multi-dimensional index on the collection if it does not already exist.

    Parameters

    Returns Promise<ArangoApiResponse<{
        fields: string[];
        figures?: Record<string, any>;
        id: string;
        name: string;
        sparse: boolean;
        type: "mdi-prefixed";
        unique: boolean;
    } & {
        estimates: boolean;
        fieldValueTypes: "double";
        prefixFields: string[];
        selectivityEstimate: number;
        storedValues?: string[];
    } & {
        isNewlyCreated: boolean;
    }>>

    Example

    const db = new Database();
    const collection = db.collection("some-points");
    // Create a multi-dimensional index for the attributes x, y and z
    await collection.ensureIndex({
    type: "mdi-prefixed",
    fields: ["x", "y", "z"],
    prefixFields: ["x"],
    fieldValueTypes: "double"
    });
    
    
  • Creates a prefixed multi-dimensional index on the collection if it does not already exist.

    Parameters

    Returns Promise<ArangoApiResponse<{
        fields: string[];
        figures?: Record<string, any>;
        id: string;
        name: string;
        sparse: boolean;
        type: "mdi-prefixed";
        unique: boolean;
    } & {
        estimates: boolean;
        fieldValueTypes: "double";
        prefixFields: string[];
        selectivityEstimate: number;
        storedValues?: string[];
    } & {
        isNewlyCreated: boolean;
    }>>

    Example

    const db = new Database();
    const collection = db.collection("some-points");
    // Create a multi-dimensional index for the attributes x, y and z
    await collection.ensureIndex({
    type: "mdi-prefixed",
    fields: ["x", "y", "z"],
    prefixFields: ["x"],
    fieldValueTypes: "double"
    });
    
    
  • Creates a geo index on the collection if it does not already exist.

    Parameters

    Returns Promise<ArangoApiResponse<{
        fields: [string] | [string, string];
        figures?: Record<string, any>;
        id: string;
        name: string;
        sparse: boolean;
        type: "geo";
        unique: boolean;
    } & {
        bestIndexedLevel: number;
        geoJson: boolean;
        legacyPolygons: boolean;
        maxNumCoverCells: number;
        worstIndexedLevel: number;
    } & {
        isNewlyCreated: boolean;
    }>>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    // Create an index for GeoJSON data
    await collection.ensureIndex({
    type: "geo",
    fields: ["lngLat"],
    geoJson: true
    });
  • Creates a inverted index on the collection if it does not already exist.

    Parameters

    Returns Promise<ArangoApiResponse<{
        fields: InvertedIndexField[];
        figures?: Record<string, any>;
        id: string;
        name: string;
        sparse: boolean;
        type: "inverted";
        unique: boolean;
    } & {
        analyzer: string;
        cache?: boolean;
        cleanupIntervalStep: number;
        commitIntervalMsec: number;
        consolidationIntervalMsec: number;
        consolidationPolicy: Required<TierConsolidationPolicy>;
        features: AnalyzerFeature[];
        includeAllFields: boolean;
        optimizeTopK: string[];
        parallelism: number;
        primaryKeyCache?: boolean;
        primarySort: {
            cache?: boolean;
            compression: Compression;
            fields: {
                direction: Direction;
                field: string;
            }[];
        };
        searchField: boolean;
        storedValues: {
            cache?: boolean;
            compression: Compression;
            fields: string[];
        }[];
        trackListPositions: boolean;
        writeBufferActive: number;
        writeBufferIdle: number;
        writeBufferSizeMax: number;
    } & {
        isNewlyCreated: boolean;
    }>>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    // Create an inverted index
    await collection.ensureIndex({
    type: "inverted",
    fields: ["a", { name: "b", analyzer: "text_en" }]
    });
  • Creates an index on the collection if it does not already exist.

    Parameters

    Returns Promise<ArangoApiResponse<IndexDescription & {
        isNewlyCreated: boolean;
    }>>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    // Create a unique index for looking up documents by username
    await collection.ensureIndex({
    type: "persistent",
    fields: ["username"],
    name: "unique-usernames",
    unique: true
    });
  • Checks whether the collection exists.

    Returns Promise<boolean>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    const result = await collection.exists();
    // result indicates whether the collection exists
  • Retrieves statistics for a collection.

    Parameters

    • Optional details: boolean

      whether to return extended storage engine-specific details to the figures, which may cause additional load and impact performance

    Returns Promise<ArangoApiResponse<CollectionDescription & CollectionProperties & {
        count: number;
        figures: Record<string, any>;
    }>>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    const data = await collection.figures();
    // data contains the collection's figures
  • Retrieves the shardId of the shard responsible for the given document.

    Parameters

    Returns Promise<string>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    const responsibleShard = await collection.getResponsibleShard();
  • Bulk imports the given data into the collection.

    Parameters

    Returns Promise<ImportDocumentsResult>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    await collection.import(
    [
    { _key: "jcd", password: "bionicman" },
    { _key: "jreyes", password: "amigo" },
    { _key: "ghermann", password: "zeitgeist" }
    ]
    );
  • Bulk imports the given data into the collection.

    Parameters

    • data: any[][]

      The data to import, as an array containing a single array of attribute names followed by one or more arrays of attribute values for each document.

    • Optional options: ImportDocumentsOptions

      Options for importing the data.

    Returns Promise<ImportDocumentsResult>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    await collection.import(
    [
    [ "_key", "password" ],
    [ "jcd", "bionicman" ],
    [ "jreyes", "amigo" ],
    [ "ghermann", "zeitgeist" ]
    ]
    );
  • Bulk imports the given data into the collection.

    If type is omitted, data must contain one JSON array per line with the first array providing the attribute names and all other arrays providing attribute values for each document.

    If type is set to "documents", data must contain one JSON document per line.

    If type is set to "list", data must contain a JSON array of documents.

    If type is set to "auto", data can be in either of the formats supported by "documents" or "list".

    Parameters

    • data: string | Buffer | Blob

      The data to import as a Buffer (Node), Blob (browser) or string.

    • Optional options: ImportDocumentsOptions & {
          type?: "documents" | "list" | "auto";
      }

      Options for importing the data.

    Returns Promise<ImportDocumentsResult>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    await collection.import(
    '{"_key":"jcd","password":"bionicman"}\r\n' +
    '{"_key":"jreyes","password":"amigo"}\r\n' +
    '{"_key":"ghermann","password":"zeitgeist"}\r\n',
    { type: "documents" } // or "auto"
    );

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    await collection.import(
    '[{"_key":"jcd","password":"bionicman"},' +
    '{"_key":"jreyes","password":"amigo"},' +
    '{"_key":"ghermann","password":"zeitgeist"}]',
    { type: "list" } // or "auto"
    );

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    await collection.import(
    '["_key","password"]\r\n' +
    '["jcd","bionicman"]\r\n' +
    '["jreyes","amigo"]\r\n' +
    '["ghermann","zeitgeist"]\r\n'
    );
  • Returns an index description by name or id if it exists.

    Parameters

    • selector: IndexSelector

      Index name, id or object with either property.

    Returns Promise<IndexDescription>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    const index = await collection.index("some-index");
  • Returns a list of all index descriptions for the collection.

    Type Parameters

    Parameters

    Returns Promise<IndexType[]>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    const indexes = await collection.indexes();

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    const allIndexes = await collection.indexes<HiddenIndexDescription>({
    withHidden: true
    });
  • Instructs ArangoDB to load as many indexes of the collection into memory as permitted by the memory limit.

    Returns Promise<boolean>

    Example

    const db = new Database();
    const collection = db.collection("indexed-collection");
    await collection.loadIndexes();
    // the indexes are now loaded into memory
  • Instructs ArangoDB to recalculate the collection's document count to fix any inconsistencies.

    Returns Promise<boolean>

    Example

    const db = new Database();
    const collection = db.collection("inconsistent-collection");
    const badData = await collection.count();
    // oh no, the collection count looks wrong -- fix it!
    await collection.recalculateCount();
    const goodData = await collection.count();
    // goodData contains the collection's improved count
  • Removes an existing document from the collection.

    Throws an exception when passed a document or _id from a different collection.

    Parameters

    • selector: DocumentSelector

      Document _key, _id or object with either of those properties (e.g. a document from this collection).

    • Optional options: RemoveDocumentOptions

      Options for removing the document.

    Returns Promise<DocumentMetadata & {
        old?: Document<EntryResultType>;
    }>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    await collection.remove("abc123");
    // document with key "abc123" deleted

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    const doc = await collection.document("abc123");
    await collection.remove(doc);
    // document with key "abc123" deleted
  • Renames the collection and updates the instance's name to newName.

    Additionally removes the instance from the databases.Database's internal cache.

    Note: Renaming collections may not be supported when ArangoDB is running in a cluster configuration.

    Parameters

    • newName: string

      The new name of the collection.

    Returns Promise<ArangoApiResponse<CollectionDescription>>

    Example

    const db = new Database();
    const collection1 = db.collection("some-collection");
    await collection1.rename("other-collection");
    const collection2 = db.collection("some-collection");
    const collection3 = db.collection("other-collection");
    // Note all three collection instances are different objects but
    // collection1 and collection3 represent the same ArangoDB collection!
  • Replaces an existing document in the collection.

    Throws an exception when passed a document or _id from a different collection.

    Parameters

    Returns Promise<DocumentMetadata & {
        _oldRev?: string;
    } & {
        new?: Document<EntryResultType>;
        old?: Document<EntryResultType>;
    }>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    await collection.save({ _key: "a", color: "blue", count: 1 });
    const result = await collection.replace(
    "a",
    { color: "red" },
    { returnNew: true }
    );
    console.log(result.new.color, result.new.count); // "red" undefined
  • Replaces existing documents in the collection, identified by the _key or _id of each document.

    Parameters

    Returns Promise<(DocumentOperationFailure | DocumentMetadata & {
        _oldRev?: string;
    } & {
        new?: Document<EntryResultType>;
        old?: Document<EntryResultType>;
    })[]>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    await collection.save({ _key: "a", color: "blue", count: 1 });
    await collection.save({ _key: "b", color: "green", count: 3 });
    const result = await collection.replaceAll(
    [
    { _key: "a", color: "red" },
    { _key: "b", color: "yellow", count: 2 }
    ],
    { returnNew: true }
    );
    console.log(result[0].new.color, result[0].new.count); // "red" undefined
    console.log(result[1].new.color, result[1].new.count); // "yellow" 2
  • Updates an existing document in the collection.

    Throws an exception when passed a document or _id from a different collection.

    Parameters

    Returns Promise<DocumentMetadata & {
        _oldRev?: string;
    } & {
        new?: Document<EntryResultType>;
        old?: Document<EntryResultType>;
    }>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    await collection.save({ _key: "a", color: "blue", count: 1 });
    const result = await collection.update(
    "a",
    { count: 2 },
    { returnNew: true }
    );
    console.log(result.new.color, result.new.count); // "blue" 2
  • Updates existing documents in the collection, identified by the _key or _id of each document.

    Parameters

    Returns Promise<(DocumentOperationFailure | DocumentMetadata & {
        _oldRev?: string;
    } & {
        new?: Document<EntryResultType>;
        old?: Document<EntryResultType>;
    })[]>

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    await collection.save({ _key: "a", color: "blue", count: 1 });
    await collection.save({ _key: "b", color: "green", count: 3 });
    const result = await collection.updateAll(
    [
    { _key: "a", count: 2 },
    { _key: "b", count: 4 }
    ],
    { returnNew: true }
    );
    console.log(result[0].new.color, result[0].new.count); // "blue" 2
    console.log(result[1].new.color, result[1].new.count); // "green" 4