Interface EdgeCollection<EntryResultType, EntryInputType>

Represents an edge collection in a databases.Database.

See DocumentCollection for a more generic variant of this interface more suited for regular document collections.

See also graphs.GraphEdgeCollection for the type representing an edge collection in a graphs.Graph.

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

Example

interface Friend {
startDate: number;
endDate?: number;
}
const db = new Database();
const edges = db.collection("friends") as EdgeCollection<Friend>;
interface EdgeCollection<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<Edge<EntryResultType>>;
    document(selector, graceful): Promise<Edge<EntryResultType>>;
    documentExists(selector, options?): Promise<boolean>;
    documentId(selector): string;
    documents(selectors, options?): Promise<Edge<EntryResultType>[]>;
    drop(options?): Promise<ArangoApiResponse<{
        id: string;
    }>>;
    dropIndex(selector): Promise<ArangoApiResponse<{
        id: string;
    }>>;
    edges(selector, options?): Promise<ArangoApiResponse<DocumentEdgesResult<EntryResultType>>>;
    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>;
    inEdges(selector, options?): Promise<ArangoApiResponse<DocumentEdgesResult<EntryResultType>>>;
    index(selector): Promise<IndexDescription>;
    indexes<IndexType>(options?): Promise<IndexType[]>;
    loadIndexes(): Promise<boolean>;
    outEdges(selector, options?): Promise<ArangoApiResponse<DocumentEdgesResult<EntryResultType>>>;
    properties(): Promise<ArangoApiResponse<CollectionDescription & CollectionProperties>>;
    properties(properties): Promise<ArangoApiResponse<CollectionDescription & CollectionProperties>>;
    recalculateCount(): Promise<boolean>;
    remove(selector, options?): Promise<DocumentMetadata & {
        old?: Edge<EntryResultType>;
    }>;
    removeAll(selectors, options?): Promise<(DocumentOperationFailure | DocumentMetadata & {
        old?: Edge<EntryResultType>;
    })[]>;
    rename(newName): Promise<ArangoApiResponse<CollectionDescription>>;
    replace(selector, newData, options?): Promise<DocumentMetadata & {
        _oldRev?: string;
    } & {
        new?: Edge<EntryResultType>;
        old?: Edge<EntryResultType>;
    }>;
    replaceAll(newData, options?): Promise<(DocumentOperationFailure | DocumentMetadata & {
        _oldRev?: string;
    } & {
        new?: Edge<EntryResultType>;
        old?: Edge<EntryResultType>;
    })[]>;
    revision(): Promise<ArangoApiResponse<CollectionDescription & CollectionProperties & {
        revision: string;
    }>>;
    save(data, options?): Promise<DocumentMetadata & {
        _oldRev?: string;
    } & {
        new?: Edge<EntryResultType>;
        old?: Edge<EntryResultType>;
    }>;
    saveAll(data, options?): Promise<(DocumentOperationFailure | DocumentMetadata & {
        _oldRev?: string;
    } & {
        new?: Edge<EntryResultType>;
        old?: Edge<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?: Edge<EntryResultType>;
        old?: Edge<EntryResultType>;
    }>;
    updateAll(newData, options?): Promise<(DocumentOperationFailure | DocumentMetadata & {
        _oldRev?: string;
    } & {
        new?: Edge<EntryResultType>;
        old?: Edge<EntryResultType>;
    })[]>;
}

Type Parameters

  • EntryResultType extends Record<string, any> = any

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

  • EntryInputType extends Record<string, any> = EntryResultType

    Type to represent edge document contents passed when inserting or replacing edge 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, or if the document does not exist.

    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<Edge<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("Document does not exist");
    }
  • Retrieves the document matching the given key or id.

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

    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<Edge<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("Document does not exist");
    }
  • 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<Edge<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
  • Retrieves a list of all edges in this collection of the document matching the given selector.

    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: DocumentEdgesOptions

      Options for retrieving the edges.

    Returns Promise<ArangoApiResponse<DocumentEdgesResult<EntryResultType>>>

    Example

    const db = new Database();
    const collection = db.collection("edges");
    await collection.import([
    ["_key", "_from", "_to"],
    ["x", "vertices/a", "vertices/b"],
    ["y", "vertices/a", "vertices/c"],
    ["z", "vertices/d", "vertices/a"],
    ]);
    const edges = await collection.edges("vertices/a");
    console.log(edges.map((edge) => edge._key)); // ["x", "y", "z"]
  • 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 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: "x", _from: "vertices/a", _to: "vertices/b", weight: 1 },
    { _key: "y", _from: "vertices/a", _to: "vertices/c", weight: 2 }
    ]
    );
  • 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 edge 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", "_from", "_to", "weight" ],
    [ "x", "vertices/a", "vertices/b", 1 ],
    [ "y", "vertices/a", "vertices/c", 2 ]
    ]
    );
  • 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 edge 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 edge 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":"x","_from":"vertices/a","_to":"vertices/b","weight":1}\r\n' +
    '{"_key":"y","_from":"vertices/a","_to":"vertices/c","weight":2}\r\n',
    { type: "documents" } // or "auto"
    );

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    await collection.import(
    '[{"_key":"x","_from":"vertices/a","_to":"vertices/b","weight":1},' +
    '{"_key":"y","_from":"vertices/a","_to":"vertices/c","weight":2}]',
    { type: "list" } // or "auto"
    );

    Example

    const db = new Database();
    const collection = db.collection("some-collection");
    await collection.import(
    '["_key","_from","_to","weight"]\r\n' +
    '["x","vertices/a","vertices/b",1]\r\n' +
    '["y","vertices/a","vertices/c",2]\r\n'
    );
  • Retrieves a list of all incoming edges of the document matching the given selector.

    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: DocumentEdgesOptions

      Options for retrieving the edges.

    Returns Promise<ArangoApiResponse<DocumentEdgesResult<EntryResultType>>>

    Example

    const db = new Database();
    const collection = db.collection("edges");
    await collection.import([
    ["_key", "_from", "_to"],
    ["x", "vertices/a", "vertices/b"],
    ["y", "vertices/a", "vertices/c"],
    ["z", "vertices/d", "vertices/a"],
    ]);
    const edges = await collection.inEdges("vertices/a");
    console.log(edges.map((edge) => edge._key)); // ["z"]
  • 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
  • Retrieves a list of all outgoing edges of the document matching the given selector.

    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: DocumentEdgesOptions

      Options for retrieving the edges.

    Returns Promise<ArangoApiResponse<DocumentEdgesResult<EntryResultType>>>

    Example

    const db = new Database();
    const collection = db.collection("edges");
    await collection.import([
    ["_key", "_from", "_to"],
    ["x", "vertices/a", "vertices/b"],
    ["y", "vertices/a", "vertices/c"],
    ["z", "vertices/d", "vertices/a"],
    ]);
    const edges = await collection.outEdges("vertices/a");
    console.log(edges.map((edge) => edge._key)); // ["x", "y"]
  • 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?: Edge<EntryResultType>;
    }>

    Example

    const db = new Database();
    const collection = db.collection("friends");
    const doc = await collection.document("musadir");
    await collection.remove(doc);
    // document with key "musadir" 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?: Edge<EntryResultType>;
        old?: Edge<EntryResultType>;
    }>

    Example

    const db = new Database();
    const collection = db.collection("friends");
    await collection.save(
    {
    _key: "musadir",
    _from: "users/rana",
    _to: "users/mudasir",
    active: true,
    best: true
    }
    );
    const result = await collection.replace(
    "musadir",
    { active: false },
    { returnNew: true }
    );
    console.log(result.new.active, result.new.best); // false undefined
  • Replaces existing documents in the collection, identified by the _key or _id of each document.

    Parameters

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

    Example

    const db = new Database();
    const collection = db.collection("friends");
    await collection.save(
    {
    _key: "musadir",
    _from: "users/rana",
    _to: "users/mudasir",
    active: true,
    best: true
    }
    );
    await collection.save(
    {
    _key: "salman",
    _from: "users/rana",
    _to: "users/salman",
    active: false,
    best: false
    }
    );
    const result = await collection.replaceAll(
    [
    { _key: "musadir", active: false },
    { _key: "salman", active: true, best: true }
    ],
    { returnNew: true }
    );
    console.log(result[0].new.active, result[0].new.best); // false undefined
    console.log(result[1].new.active, result[1].new.best); // true true
  • 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?: Edge<EntryResultType>;
        old?: Edge<EntryResultType>;
    }>

    Example

    const db = new Database();
    const collection = db.collection("friends");
    await collection.save(
    {
    _key: "musadir",
    _from: "users/rana",
    _to: "users/mudasir",
    active: true,
    best: true
    }
    );
    const result = await collection.update(
    "musadir",
    { active: false },
    { returnNew: true }
    );
    console.log(result.new.active, result.new.best); // false true
  • Updates existing documents in the collection, identified by the _key or _id of each document.

    Parameters

    • newData: (Patch<DocumentData<EntryInputType>> & ({
          _key: string;
      } | {
          _id: string;
      }))[]

      The data for updating the documents.

    • Optional options: UpdateDocumentOptions

      Options for updating the documents.

      const db = new Database();
      const collection = db.collection("friends");
      await collection.save(
      {
      _key: "musadir",
      _from: "users/rana",
      _to: "users/mudasir",
      active: true,
      best: true
      }
      );
      await collection.save(
      {
      _key: "salman",
      _from: "users/rana",
      _to: "users/salman",
      active: false,
      best: false
      }
      );
      const result = await collection.updateAll(
      [
      { _key: "musadir", active: false },
      { _key: "salman", active: true, best: true }
      ],
      { returnNew: true }
      );
      console.log(result[0].new.active, result[0].new.best); // false true
      console.log(result[1].new.active, result[1].new.best); // true true

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