ArangoDB v3.11 reached End of Life (EOL) and is no longer supported.
This documentation is outdated. Please see the most recent stable version.
HTTP interface for arangosearch Views
The HTTP API for Views lets you manage arangosearch Views, including handling the general View properties and View links
Create an arangosearch View
- cleanupIntervalStep integer (default:- 2)- Wait at least this many commits between removing unused files in the ArangoSearch data directory ( - 0= disable). For the case where the consolidation policies merge segments often (i.e. a lot of commit+consolidate), a lower value causes a lot of disk space to be wasted. For the case where the consolidation policies rarely merge segments (i.e. few inserts/deletes), a higher value impacts performance without any added benefits.- Background: With every “commit” or “consolidate” operation, a new state of the View’s internal data structures is created on disk. Old states/snapshots are released once there are no longer any users remaining. However, the files for the released states/snapshots are left on disk, and only removed by “cleanup” operation. 
- commitIntervalMsec integer (default:- 1000)- Wait at least this many milliseconds between committing View data store changes and making documents visible to queries ( - 0= disable). For the case where there are a lot of inserts/updates, a higher value causes the index not to account for them and memory usage continues to grow until the commit. A lower value impacts performance, including the case where there are no or only a few inserts/updates because of synchronous locking, and it wastes disk space for each commit call.- Background: For data retrieval, ArangoSearch follows the concept of “eventually-consistent”, i.e. eventually all the data in ArangoDB will be matched by corresponding query expressions. The concept of ArangoSearch “commit” operations is introduced to control the upper-bound on the time until document addition/removals are actually reflected by corresponding query expressions. Once a “commit” operation is complete, all documents added/removed prior to the start of the “commit” operation will be reflected by queries invoked in subsequent ArangoDB transactions, in-progress ArangoDB transactions will still continue to return a repeatable-read state. 
- consolidationIntervalMsec integer (default:- 10000)- Wait at least this many milliseconds between applying - consolidationPolicyto consolidate the View data store and possibly release space on the filesystem (- 0= disable). For the case where there are a lot of data modification operations, a higher value could potentially have the data store consume more space and file handles. For the case where there are a few data modification operations, a lower value impacts performance due to no segment candidates being available for consolidation.- Background: For data modification, ArangoSearch follows the concept of a “versioned data store”. Thus old versions of data may be removed once there are no longer any users of the old data. The frequency of the cleanup and compaction operations are governed by - consolidationIntervalMsecand the candidates for compaction are selected via- consolidationPolicy.
- consolidationPolicy object- The consolidation policy to apply for selecting which segments should be merged. - If the tiertype is used, then thesegments*andminScoreproperties are available.
- If the bytes_accumtype is used, then thethresholdproperty is available.
 - Background: With each ArangoDB transaction that inserts documents, one or more ArangoSearch-internal segments get created. Similarly, for removed documents, the segments that contain such documents have these documents marked as ‘deleted’. Over time, this approach causes a lot of small and sparse segments to be created. A “consolidation” operation selects one or more segments and copies all of their valid documents into a single new segment, thereby allowing the search algorithm to perform more optimally and for extra file handles to be released once old segments are no longer used. - type* string (default:- "tier")- Possible values: - "tier",- "bytes_accum"- The segment candidates for the “consolidation” operation are selected based upon several possible configurable formulas as defined by their types. The currently supported types are: - "tier": consolidate based on segment byte size and live document count as dictated by the customization attributes.
- "bytes_accum": consolidate if and only if- {threshold} > (segment_bytes + sum_of_merge_candidate_segment_bytes) / all_segment_bytesi.e. the sum of all candidate segment byte size is less than the total segment byte size multiplied by the- {threshold}.
 
 
- If the 
- links object- Expects an object with the attribute keys being names of to be linked collections, and the link properties as attribute values. Example: - { "name": "arangosearch", "links": { "coll": { "fields": { "my_attribute": { "fields": { "my_sub_attribute": { "analyzers": ["text_en"] } } } } } } }- See - arangosearchView Link Properties for details.
- primaryKeyCache boolean- If you enable this option, then the primary key columns are always cached in memory (introduced in v3.9.6, Enterprise Edition only). This can improve the performance of queries that return many documents. Otherwise, these values are memory-mapped and it is up to the operating system to load them from disk into memory and to evict them from memory. - This option is immutable. - See the - --arangosearch.columns-cache-limitstartup option to control the memory consumption of this cache. You can reduce the memory usage of the column cache in cluster deployments by only using the cache for leader shards, see the- --arangosearch.columns-cache-only-leaderstartup option (introduced in v3.10.6).
- primarySort array of objects (default:- [])- You can define a primary sort order to enable an AQL optimization. If a query iterates over all documents of a View, wants to sort them by attribute values and the (left-most) fields to sort by as well as their sorting direction match with the - primarySortdefinition, then the- SORToperation is optimized away. This option is immutable.- Expects an array of objects, each specifying a field (attribute path) and a sort direction: - [ { "field": "attr", "direction": "asc"}, … ]
- primarySortCache boolean- If you enable this option, then the primary sort columns are always cached in memory (Enterprise Edition only). This can improve the performance of queries that utilize the primary sort order. Otherwise, these values are memory-mapped and it is up to the operating system to load them from disk into memory and to evict them from memory. - This option is immutable. - See the - --arangosearch.columns-cache-limitstartup option to control the memory consumption of this cache. You can reduce the memory usage of the column cache in cluster deployments by only using the cache for leader shards, see the- --arangosearch.columns-cache-only-leaderstartup option.
- storedValues array of objects (default:- [])- An array of objects to describe which document attributes to store in the View index. It can then cover search queries, which means the data can be taken from the index directly and accessing the storage engine can be avoided. - This option is immutable. - Each object is expected in the following form: - { "fields": [ "attr1", "attr2", ... "attrN" ], "compression": "none", "cache": false }- You may use the following shorthand notations on View creation instead of an array of objects as described above. The default compression and cache settings are used in this case: - An array of strings, like - ["attr1", "attr2"], to place each attribute into a separate column of the index.
- An array of arrays of strings, like - [["attr1", "attr2"]], to place the attributes into a single column of the index, or- [["attr1"], ["attr2"]]to place each attribute into a separate column. You can also mix it with the full form:- [ ["attr1"], ["attr2", "attr3"], { "fields": ["attr4", "attr5"], "cache": true } ]
 - The - storedValuesoption is not to be confused with the- storeValuesoption, which allows to store meta data about attribute values in the View index.- cache boolean (default:- false)- Whether to always cache stored values in memory (Enterprise Edition only). This can improve the query performance if stored values are involved. Otherwise, these values are memory-mapped and it is up to the operating system to load them from disk into memory and to evict them from memory. - See the - --arangosearch.columns-cache-limitstartup option to control the memory consumption of this cache. You can reduce the memory usage of the column cache in cluster deployments by only using the cache for leader shards, see the- --arangosearch.columns-cache-only-leaderstartup option.
- fields* array of strings- An array of strings with one or more document attribute paths. The specified attributes are placed into a single column of the index. A column with all fields that are involved in common search queries is ideal for performance. The column should not include too many unneeded fields, however. 
 
- writebufferSizeMax integer (default:- 33554432)- Maximum memory byte size per writer (segment) before a writer (segment) flush is triggered. The value - 0turns off this limit for any writer (buffer) and data is flushed periodically based on the value defined for the flush thread (ArangoDB server startup option). This should be used carefully due to high potential memory consumption (immutable,- 0= disable).
- 201 Created- The View has been created. - consolidationPolicy* object- The consolidation policy to apply for selecting which segments should be merged. - If the tiertype is used, then thesegments*andminScoreproperties are available.
- If the bytes_accumtype is used, then thethresholdproperty is available.
 - type string- Possible values: - "tier",- "bytes_accum"- The segment candidates for the “consolidation” operation are selected based upon several possible configurable formulas as defined by their types. The currently supported types are: - "tier": consolidate based on segment byte size and live document count as dictated by the customization attributes.
- "bytes_accum": consolidate if and only if- {threshold} > (segment_bytes + sum_of_merge_candidate_segment_bytes) / all_segment_bytesi.e. the sum of all candidate segment byte size is less than the total segment byte size multiplied by the- {threshold}.
 
 
- If the 
- links* object- An object with the attribute keys being names of to be linked collections, and the link properties as attribute values. See - arangosearchView Link Properties for details.
 Response Body application/json object
Examples
curl -X POST --header 'accept: application/json' --data-binary @- --dump - 'http://localhost:8529/_api/view' <<'EOF'
{
  "name": "products",
  "type": "arangosearch"
}
EOFShow output
HTTP/1.1 201 Created
content-type: application/json
cache-control: no-cache, no-store, must-revalidate, pre-check=0, post-check=0, max-age=0, s-maxage=0
connection: Keep-Alive
content-length: 471
content-security-policy: frame-ancestors 'self'; form-action 'self';
expires: 0
pragma: no-cache
server: ArangoDB
strict-transport-security: max-age=31536000 ; includeSubDomains
x-arango-queue-time-seconds: 0.000000
x-content-type-options: nosniff
{ 
  "globallyUniqueId" : "h68138D6305DA/72488", 
  "id" : "72488", 
  "name" : "products", 
  "type" : "arangosearch", 
  "cleanupIntervalStep" : 2, 
  "commitIntervalMsec" : 1000, 
  "consolidationIntervalMsec" : 1000, 
  "consolidationPolicy" : { 
    "type" : "tier", 
    "segmentsBytesFloor" : 2097152, 
    "segmentsBytesMax" : 5368709120, 
    "segmentsMax" : 10, 
    "segmentsMin" : 1, 
    "minScore" : 0 
  }, 
  "primarySort" : [ ], 
  "primarySortCompression" : "lz4", 
  "storedValues" : [ ], 
  "writebufferActive" : 0, 
  "writebufferIdle" : 64, 
  "writebufferSizeMax" : 33554432, 
  "links" : { 
  } 
}Get information about a View
Examples
Using an identifier:
curl --header 'accept: application/json' --dump - 'http://localhost:8529/_api/view/72618'Show output
HTTP/1.1 200 OK
content-type: application/json
cache-control: no-cache, no-store, must-revalidate, pre-check=0, post-check=0, max-age=0, s-maxage=0
connection: Keep-Alive
content-length: 124
content-security-policy: frame-ancestors 'self'; form-action 'self';
expires: 0
pragma: no-cache
server: ArangoDB
strict-transport-security: max-age=31536000 ; includeSubDomains
x-arango-queue-time-seconds: 0.000000
x-content-type-options: nosniff
{ 
  "error" : false, 
  "code" : 200, 
  "type" : "arangosearch", 
  "name" : "productsView", 
  "id" : "72618", 
  "globallyUniqueId" : "h68138D6305DA/72618" 
}Using a name:
curl --header 'accept: application/json' --dump - 'http://localhost:8529/_api/view/productsView'Show output
HTTP/1.1 200 OK
content-type: application/json
cache-control: no-cache, no-store, must-revalidate, pre-check=0, post-check=0, max-age=0, s-maxage=0
connection: Keep-Alive
content-length: 124
content-security-policy: frame-ancestors 'self'; form-action 'self';
expires: 0
pragma: no-cache
server: ArangoDB
strict-transport-security: max-age=31536000 ; includeSubDomains
x-arango-queue-time-seconds: 0.000000
x-content-type-options: nosniff
{ 
  "error" : false, 
  "code" : 200, 
  "type" : "arangosearch", 
  "name" : "productsView", 
  "id" : "72622", 
  "globallyUniqueId" : "h68138D6305DA/72622" 
}Get the properties of a View
view-name.- 200 OK- An object with a full description of the specified View, including - arangosearchView type-dependent properties.- consolidationPolicy* object- The consolidation policy to apply for selecting which segments should be merged. - If the tiertype is used, then thesegments*andminScoreproperties are available.
- If the bytes_accumtype is used, then thethresholdproperty is available.
 - type string- Possible values: - "tier",- "bytes_accum"- The segment candidates for the “consolidation” operation are selected based upon several possible configurable formulas as defined by their types. The currently supported types are: - "tier": consolidate based on segment byte size and live document count as dictated by the customization attributes.
- "bytes_accum": consolidate if and only if- {threshold} > (segment_bytes + sum_of_merge_candidate_segment_bytes) / all_segment_bytesi.e. the sum of all candidate segment byte size is less than the total segment byte size multiplied by the- {threshold}.
 
 
- If the 
- links* object- An object with the attribute keys being names of to be linked collections, and the link properties as attribute values. See - arangosearchView Link Properties for details.
 Response Body application/json object
Examples
Using an identifier:
curl --header 'accept: application/json' --dump - 'http://localhost:8529/_api/view/72505/properties'Show output
HTTP/1.1 200 OK
content-type: application/json
cache-control: no-cache, no-store, must-revalidate, pre-check=0, post-check=0, max-age=0, s-maxage=0
connection: Keep-Alive
content-length: 652
content-security-policy: frame-ancestors 'self'; form-action 'self';
expires: 0
pragma: no-cache
server: ArangoDB
strict-transport-security: max-age=31536000 ; includeSubDomains
x-arango-queue-time-seconds: 0.000000
x-content-type-options: nosniff
{ 
  "error" : false, 
  "code" : 200, 
  "writebufferSizeMax" : 33554432, 
  "id" : "72505", 
  "storedValues" : [ ], 
  "name" : "productsView", 
  "type" : "arangosearch", 
  "consolidationPolicy" : { 
    "type" : "tier", 
    "segmentsBytesFloor" : 2097152, 
    "segmentsBytesMax" : 5368709120, 
    "segmentsMax" : 10, 
    "segmentsMin" : 1, 
    "minScore" : 0 
  }, 
  "writebufferActive" : 0, 
  "links" : { 
    "books" : { 
      "analyzers" : [ 
        "identity" 
      ], 
      "fields" : { 
        "title" : { 
          "analyzers" : [ 
            "text_en" 
          ] 
        } 
      }, 
      "includeAllFields" : false, 
      "storeValues" : "none", 
      "trackListPositions" : false 
    } 
  }, 
  "commitIntervalMsec" : 1000, 
  "consolidationIntervalMsec" : 1000, 
  "globallyUniqueId" : "h68138D6305DA/72505", 
  "cleanupIntervalStep" : 2, 
  "primarySort" : [ ], 
  "primarySortCompression" : "lz4", 
  "writebufferIdle" : 64 
}Using a name:
curl --header 'accept: application/json' --dump - 'http://localhost:8529/_api/view/productsView/properties'Show output
HTTP/1.1 200 OK
content-type: application/json
cache-control: no-cache, no-store, must-revalidate, pre-check=0, post-check=0, max-age=0, s-maxage=0
connection: Keep-Alive
content-length: 652
content-security-policy: frame-ancestors 'self'; form-action 'self';
expires: 0
pragma: no-cache
server: ArangoDB
strict-transport-security: max-age=31536000 ; includeSubDomains
x-arango-queue-time-seconds: 0.000000
x-content-type-options: nosniff
{ 
  "error" : false, 
  "code" : 200, 
  "writebufferSizeMax" : 33554432, 
  "id" : "72521", 
  "storedValues" : [ ], 
  "name" : "productsView", 
  "type" : "arangosearch", 
  "consolidationPolicy" : { 
    "type" : "tier", 
    "segmentsBytesFloor" : 2097152, 
    "segmentsBytesMax" : 5368709120, 
    "segmentsMax" : 10, 
    "segmentsMin" : 1, 
    "minScore" : 0 
  }, 
  "writebufferActive" : 0, 
  "links" : { 
    "books" : { 
      "analyzers" : [ 
        "identity" 
      ], 
      "fields" : { 
        "title" : { 
          "analyzers" : [ 
            "text_en" 
          ] 
        } 
      }, 
      "includeAllFields" : false, 
      "storeValues" : "none", 
      "trackListPositions" : false 
    } 
  }, 
  "commitIntervalMsec" : 1000, 
  "consolidationIntervalMsec" : 1000, 
  "globallyUniqueId" : "h68138D6305DA/72521", 
  "cleanupIntervalStep" : 2, 
  "primarySort" : [ ], 
  "primarySortCompression" : "lz4", 
  "writebufferIdle" : 64 
}List all Views
Examples
Return information about all Views:
curl --header 'accept: application/json' --dump - 'http://localhost:8529/_api/view'Show output
HTTP/1.1 200 OK
content-type: application/json
cache-control: no-cache, no-store, must-revalidate, pre-check=0, post-check=0, max-age=0, s-maxage=0
connection: Keep-Alive
content-length: 328
content-security-policy: frame-ancestors 'self'; form-action 'self';
expires: 0
pragma: no-cache
server: ArangoDB
strict-transport-security: max-age=31536000 ; includeSubDomains
x-arango-queue-time-seconds: 0.000000
x-content-type-options: nosniff
{ 
  "error" : false, 
  "code" : 200, 
  "result" : [ 
    { 
      "globallyUniqueId" : "h68138D6305DA/132", 
      "id" : "132", 
      "name" : "demoView", 
      "type" : "arangosearch" 
    }, 
    { 
      "globallyUniqueId" : "h68138D6305DA/72646", 
      "id" : "72646", 
      "name" : "productsView", 
      "type" : "search-alias" 
    }, 
    { 
      "globallyUniqueId" : "h68138D6305DA/72647", 
      "id" : "72647", 
      "name" : "reviewsView", 
      "type" : "arangosearch" 
    } 
  ] 
}Replace the properties of an arangosearch View
- cleanupIntervalStep integer (default:- 2)- Wait at least this many commits between removing unused files in the ArangoSearch data directory ( - 0= disable). For the case where the consolidation policies merge segments often (i.e. a lot of commit+consolidate), a lower value causes a lot of disk space to be wasted. For the case where the consolidation policies rarely merge segments (i.e. few inserts/deletes), a higher value impacts performance without any added benefits.- Background: With every “commit” or “consolidate” operation, a new state of the View’s internal data structures is created on disk. Old states/snapshots are released once there are no longer any users remaining. However, the files for the released states/snapshots are left on disk, and only removed by “cleanup” operation. 
- commitIntervalMsec integer (default:- 1000)- Wait at least this many milliseconds between committing View data store changes and making documents visible to queries ( - 0= disable). For the case where there are a lot of inserts/updates, a higher value causes the index not to account for them and memory usage continues to grow until the commit. A lower value impacts performance, including the case where there are no or only a few inserts/updates because of synchronous locking, and it wastes disk space for each commit call.- Background: For data retrieval, ArangoSearch follows the concept of “eventually-consistent”, i.e. eventually all the data in ArangoDB will be matched by corresponding query expressions. The concept of ArangoSearch “commit” operations is introduced to control the upper-bound on the time until document addition/removals are actually reflected by corresponding query expressions. Once a “commit” operation is complete, all documents added/removed prior to the start of the “commit” operation will be reflected by queries invoked in subsequent ArangoDB transactions, in-progress ArangoDB transactions will still continue to return a repeatable-read state. 
- consolidationIntervalMsec integer (default:- 10000)- Wait at least this many milliseconds between applying - consolidationPolicyto consolidate the View data store and possibly release space on the filesystem (- 0= disable). For the case where there are a lot of data modification operations, a higher value could potentially have the data store consume more space and file handles. For the case where there are a few data modification operations, a lower value impacts performance due to no segment candidates being available for consolidation.- Background: For data modification, ArangoSearch follows the concept of a “versioned data store”. Thus old versions of data may be removed once there are no longer any users of the old data. The frequency of the cleanup and compaction operations are governed by - consolidationIntervalMsecand the candidates for compaction are selected via- consolidationPolicy.
- consolidationPolicy object- The consolidation policy to apply for selecting which segments should be merged. - If the tiertype is used, then thesegments*andminScoreproperties are available.
- If the bytes_accumtype is used, then thethresholdproperty is available.
 - Background: With each ArangoDB transaction that inserts documents, one or more ArangoSearch-internal segments get created. Similarly, for removed documents, the segments that contain such documents have these documents marked as ‘deleted’. Over time, this approach causes a lot of small and sparse segments to be created. A “consolidation” operation selects one or more segments and copies all of their valid documents into a single new segment, thereby allowing the search algorithm to perform more optimally and for extra file handles to be released once old segments are no longer used. - type* string (default:- "tier")- Possible values: - "tier",- "bytes_accum"- The segment candidates for the “consolidation” operation are selected based upon several possible configurable formulas as defined by their types. The currently supported types are: - "tier": consolidate based on segment byte size and live document count as dictated by the customization attributes.
- "bytes_accum": consolidate if and only if- {threshold} > (segment_bytes + sum_of_merge_candidate_segment_bytes) / all_segment_bytesi.e. the sum of all candidate segment byte size is less than the total segment byte size multiplied by the- {threshold}.
 
 
- If the 
- links object- Expects an object with the attribute keys being names of to be linked collections, and the link properties as attribute values. Example: - { "name": "arangosearch", "links": { "coll": { "fields": { "my_attribute": { "fields": { "my_sub_attribute": { "analyzers": ["text_en"] } } } } } } }- See - arangosearchView Link Properties for details.
- 200 OK- The View has been updated successfully. - consolidationPolicy* object- The consolidation policy to apply for selecting which segments should be merged. - If the tiertype is used, then thesegments*andminScoreproperties are available.
- If the bytes_accumtype is used, then thethresholdproperty is available.
 - type string- Possible values: - "tier",- "bytes_accum"- The segment candidates for the “consolidation” operation are selected based upon several possible configurable formulas as defined by their types. The currently supported types are: - "tier": consolidate based on segment byte size and live document count as dictated by the customization attributes.
- "bytes_accum": consolidate if and only if- {threshold} > (segment_bytes + sum_of_merge_candidate_segment_bytes) / all_segment_bytesi.e. the sum of all candidate segment byte size is less than the total segment byte size multiplied by the- {threshold}.
 
 
- If the 
- links* object- An object with the attribute keys being names of to be linked collections, and the link properties as attribute values. See - arangosearchView Link Properties for details.
 Response Body application/json object
Examples
Replace the properties of an arangosearch View including any links with new
properties. All mutable properties that are not specified are reset to their
default values.
curl -X PUT --header 'accept: application/json' --data-binary @- --dump - 'http://localhost:8529/_api/view/productsView/properties' <<'EOF'
{
  "cleanupIntervalStep": 12,
  "links": {
    "products": {
      "fields": {
        "description": {
          "analyzers": [
            "text_en"
          ]
        }
      }
    }
  }
}
EOFShow output
HTTP/1.1 200 OK
content-type: application/json
cache-control: no-cache, no-store, must-revalidate, pre-check=0, post-check=0, max-age=0, s-maxage=0
connection: Keep-Alive
content-length: 637
content-security-policy: frame-ancestors 'self'; form-action 'self';
expires: 0
pragma: no-cache
server: ArangoDB
strict-transport-security: max-age=31536000 ; includeSubDomains
x-arango-queue-time-seconds: 0.000000
x-content-type-options: nosniff
{ 
  "globallyUniqueId" : "h68138D6305DA/72548", 
  "id" : "72548", 
  "name" : "productsView", 
  "type" : "arangosearch", 
  "cleanupIntervalStep" : 12, 
  "commitIntervalMsec" : 1000, 
  "consolidationIntervalMsec" : 1000, 
  "consolidationPolicy" : { 
    "type" : "tier", 
    "segmentsBytesFloor" : 2097152, 
    "segmentsBytesMax" : 5368709120, 
    "segmentsMax" : 10, 
    "segmentsMin" : 1, 
    "minScore" : 0 
  }, 
  "primarySort" : [ ], 
  "primarySortCompression" : "lz4", 
  "storedValues" : [ ], 
  "writebufferActive" : 0, 
  "writebufferIdle" : 64, 
  "writebufferSizeMax" : 33554432, 
  "links" : { 
    "products" : { 
      "analyzers" : [ 
        "identity" 
      ], 
      "fields" : { 
        "description" : { 
          "analyzers" : [ 
            "text_en" 
          ] 
        } 
      }, 
      "includeAllFields" : false, 
      "storeValues" : "none", 
      "trackListPositions" : false 
    } 
  } 
}Update the properties of an arangosearch View
- cleanupIntervalStep integer- Wait at least this many commits between removing unused files in the ArangoSearch data directory ( - 0= disable). For the case where the consolidation policies merge segments often (i.e. a lot of commit+consolidate), a lower value causes a lot of disk space to be wasted. For the case where the consolidation policies rarely merge segments (i.e. few inserts/deletes), a higher value impacts performance without any added benefits.- Background: With every “commit” or “consolidate” operation, a new state of the View’s internal data structures is created on disk. Old states/snapshots are released once there are no longer any users remaining. However, the files for the released states/snapshots are left on disk, and only removed by “cleanup” operation. 
- commitIntervalMsec integer- Wait at least this many milliseconds between committing View data store changes and making documents visible to queries ( - 0= disable). For the case where there are a lot of inserts/updates, a higher value causes the index not to account for them and memory usage continues to grow until the commit. A lower value impacts performance, including the case where there are no or only a few inserts/updates because of synchronous locking, and it wastes disk space for each commit call.- Background: For data retrieval, ArangoSearch follows the concept of “eventually-consistent”, i.e. eventually all the data in ArangoDB will be matched by corresponding query expressions. The concept of ArangoSearch “commit” operations is introduced to control the upper-bound on the time until document addition/removals are actually reflected by corresponding query expressions. Once a “commit” operation is complete, all documents added/removed prior to the start of the “commit” operation will be reflected by queries invoked in subsequent ArangoDB transactions, in-progress ArangoDB transactions will still continue to return a repeatable-read state. 
- consolidationIntervalMsec integer- Wait at least this many milliseconds between applying - consolidationPolicyto consolidate the View data store and possibly release space on the filesystem (- 0= disable). For the case where there are a lot of data modification operations, a higher value could potentially have the data store consume more space and file handles. For the case where there are a few data modification operations, a lower value impacts performance due to no segment candidates being available for consolidation.- Background: For data modification, ArangoSearch follows the concept of a “versioned data store”. Thus old versions of data may be removed once there are no longer any users of the old data. The frequency of the cleanup and compaction operations are governed by - consolidationIntervalMsecand the candidates for compaction are selected via- consolidationPolicy.
- consolidationPolicy object- The consolidation policy to apply for selecting which segments should be merged. - If the tiertype is used, then thesegments*andminScoreproperties are available.
- If the bytes_accumtype is used, then thethresholdproperty is available.
 - Background: With each ArangoDB transaction that inserts documents, one or more ArangoSearch-internal segments get created. Similarly, for removed documents, the segments that contain such documents have these documents marked as ‘deleted’. Over time, this approach causes a lot of small and sparse segments to be created. A “consolidation” operation selects one or more segments and copies all of their valid documents into a single new segment, thereby allowing the search algorithm to perform more optimally and for extra file handles to be released once old segments are no longer used. - type* string- Possible values: - "tier",- "bytes_accum"- The segment candidates for the “consolidation” operation are selected based upon several possible configurable formulas as defined by their types. The currently supported types are: - "tier": consolidate based on segment byte size and live document count as dictated by the customization attributes.
- "bytes_accum": consolidate if and only if- {threshold} > (segment_bytes + sum_of_merge_candidate_segment_bytes) / all_segment_bytesi.e. the sum of all candidate segment byte size is less than the total segment byte size multiplied by the- {threshold}.
 
 
- If the 
- links object- Expects an object with the attribute keys being names of to be linked collections, and the link properties as attribute values. Example: - { "name": "arangosearch", "links": { "coll": { "fields": { "my_attribute": { "fields": { "my_sub_attribute": { "analyzers": ["text_en"] } } } } } } }- See - arangosearchView Link Properties for details.
- 200 OK- The View has been updated successfully. - consolidationPolicy* object- The consolidation policy to apply for selecting which segments should be merged. - If the tiertype is used, then thesegments*andminScoreproperties are available.
- If the bytes_accumtype is used, then thethresholdproperty is available.
 - type string- Possible values: - "tier",- "bytes_accum"- The segment candidates for the “consolidation” operation are selected based upon several possible configurable formulas as defined by their types. The currently supported types are: - "tier": consolidate based on segment byte size and live document count as dictated by the customization attributes.
- "bytes_accum": consolidate if and only if- {threshold} > (segment_bytes + sum_of_merge_candidate_segment_bytes) / all_segment_bytesi.e. the sum of all candidate segment byte size is less than the total segment byte size multiplied by the- {threshold}.
 
 
- If the 
- links* object- An object with the attribute keys being names of to be linked collections, and the link properties as attribute values. See - arangosearchView Link Properties for details.
 Response Body application/json object
Examples
Update the properties of an arangosearch View, only changing one setting
and removing a link. All other mutable properties that are not specified
keep their current values.
curl -X PATCH --header 'accept: application/json' --data-binary @- --dump - 'http://localhost:8529/_api/view/productsView/properties' <<'EOF'
{
  "cleanupIntervalStep": 12,
  "links": {
    "products": null
  }
}
EOFShow output
HTTP/1.1 200 OK
content-type: application/json
cache-control: no-cache, no-store, must-revalidate, pre-check=0, post-check=0, max-age=0, s-maxage=0
connection: Keep-Alive
content-length: 592
content-security-policy: frame-ancestors 'self'; form-action 'self';
expires: 0
pragma: no-cache
server: ArangoDB
strict-transport-security: max-age=31536000 ; includeSubDomains
x-arango-queue-time-seconds: 0.000000
x-content-type-options: nosniff
{ 
  "globallyUniqueId" : "h68138D6305DA/72579", 
  "id" : "72579", 
  "name" : "productsView", 
  "type" : "arangosearch", 
  "cleanupIntervalStep" : 12, 
  "commitIntervalMsec" : 666, 
  "consolidationIntervalMsec" : 666, 
  "consolidationPolicy" : { 
    "type" : "tier", 
    "segmentsBytesFloor" : 2097152, 
    "segmentsBytesMax" : 5368709120, 
    "segmentsMax" : 10, 
    "segmentsMin" : 1, 
    "minScore" : 0 
  }, 
  "primarySort" : [ ], 
  "primarySortCompression" : "lz4", 
  "storedValues" : [ ], 
  "writebufferActive" : 0, 
  "writebufferIdle" : 64, 
  "writebufferSizeMax" : 33554432, 
  "links" : { 
    "users" : { 
      "analyzers" : [ 
        "identity" 
      ], 
      "fields" : { 
      }, 
      "includeAllFields" : true, 
      "storeValues" : "none", 
      "trackListPositions" : false 
    } 
  } 
}Rename a View
Renames a View.
- 200 OK- The View has been renamed successfully. - consolidationPolicy* object- The consolidation policy to apply for selecting which segments should be merged. - If the tiertype is used, then thesegments*andminScoreproperties are available.
- If the bytes_accumtype is used, then thethresholdproperty is available.
 - type string- Possible values: - "tier",- "bytes_accum"- The segment candidates for the “consolidation” operation are selected based upon several possible configurable formulas as defined by their types. The currently supported types are: - "tier": consolidate based on segment byte size and live document count as dictated by the customization attributes.
- "bytes_accum": consolidate if and only if- {threshold} > (segment_bytes + sum_of_merge_candidate_segment_bytes) / all_segment_bytesi.e. the sum of all candidate segment byte size is less than the total segment byte size multiplied by the- {threshold}.
 
 
- If the 
- links* object- An object with the attribute keys being names of to be linked collections, and the link properties as attribute values. See - arangosearchView Link Properties for details.
 Response Body application/json object
Examples
curl -X PUT --header 'accept: application/json' --data-binary @- --dump - 'http://localhost:8529/_api/view/productsView/rename' <<'EOF'
{
  "name": "catalogView"
}
EOFShow output
HTTP/1.1 200 OK
content-type: application/json
cache-control: no-cache, no-store, must-revalidate, pre-check=0, post-check=0, max-age=0, s-maxage=0
connection: Keep-Alive
content-length: 474
content-security-policy: frame-ancestors 'self'; form-action 'self';
expires: 0
pragma: no-cache
server: ArangoDB
strict-transport-security: max-age=31536000 ; includeSubDomains
x-arango-queue-time-seconds: 0.000000
x-content-type-options: nosniff
{ 
  "globallyUniqueId" : "h68138D6305DA/72678", 
  "id" : "72678", 
  "name" : "catalogView", 
  "type" : "arangosearch", 
  "cleanupIntervalStep" : 2, 
  "commitIntervalMsec" : 1000, 
  "consolidationIntervalMsec" : 1000, 
  "consolidationPolicy" : { 
    "type" : "tier", 
    "segmentsBytesFloor" : 2097152, 
    "segmentsBytesMax" : 5368709120, 
    "segmentsMax" : 10, 
    "segmentsMin" : 1, 
    "minScore" : 0 
  }, 
  "primarySort" : [ ], 
  "primarySortCompression" : "lz4", 
  "storedValues" : [ ], 
  "writebufferActive" : 0, 
  "writebufferIdle" : 64, 
  "writebufferSizeMax" : 33554432, 
  "links" : { 
  } 
}Drop a View
view-name.Examples
Using an identifier:
curl -X DELETE --header 'accept: application/json' --dump - 'http://localhost:8529/_api/view/72684'Show output
HTTP/1.1 200 OK
content-type: application/json
cache-control: no-cache, no-store, must-revalidate, pre-check=0, post-check=0, max-age=0, s-maxage=0
connection: Keep-Alive
content-length: 40
content-security-policy: frame-ancestors 'self'; form-action 'self';
expires: 0
pragma: no-cache
server: ArangoDB
strict-transport-security: max-age=31536000 ; includeSubDomains
x-arango-queue-time-seconds: 0.000000
x-content-type-options: nosniff
{ 
  "error" : false, 
  "code" : 200, 
  "result" : true 
}Using a name:
curl -X DELETE --header 'accept: application/json' --dump - 'http://localhost:8529/_api/view/productsView'Show output
HTTP/1.1 200 OK
content-type: application/json
cache-control: no-cache, no-store, must-revalidate, pre-check=0, post-check=0, max-age=0, s-maxage=0
connection: Keep-Alive
content-length: 40
content-security-policy: frame-ancestors 'self'; form-action 'self';
expires: 0
pragma: no-cache
server: ArangoDB
strict-transport-security: max-age=31536000 ; includeSubDomains
x-arango-queue-time-seconds: 0.000000
x-content-type-options: nosniff
{ 
  "error" : false, 
  "code" : 200, 
  "result" : true 
}
