The /documents route allows you to create, manage, and delete documents.

Learn more about documents.

Get documents with POST

POST
/indexes/{index_uid}/documents/fetch

Get a set of documents.

Use offset and limit to browse through documents.

filter will not work without first explicitly adding attributes to the filterableAttributes list. Learn more about filters in our dedicated guide.

Path parameters

NameTypeDescription
index_uid *Stringuid of the requested index

Body

NameTypeDefault ValueDescription
offsetInteger0Number of documents to skip
limitInteger20Number of documents to return
fieldsArray of strings/null*Document attributes to show (case-sensitive, comma-separated)
filterString/Array of array of strings/nullN/ARefine results based on attributes in the filterableAttributes list
retrieveVectorsBooleanfalseReturn document vector data with search result
idsArray of primary keysnullReturn documents based on their primary keys

Sending an empty payload (--data-binary '{}') will return all documents in the index.

Response

NameTypeDescription
resultsArrayAn array of documents
offsetIntegerNumber of documents skipped
limitIntegerNumber of documents returned
totalIntegerTotal number of documents in the index

Returned document order

/indexes/{index_uid}/documents/fetch and /indexes/{index_uid}/documents responses do not return documents following the order of their primary keys.

Example

curl \
  -X POST MEILISEARCH_URL/indexes/books/documents/fetch \
  -H 'Content-Type: application/json' \
  --data-binary '{
    "filter": "(rating > 3 AND (genres = Adventure OR genres = Fiction)) AND language = English",
    "fields": ["title", "genres", "rating", "language"],
    "limit": 3
  }'

Response: 200 Ok

{
  "results": [
    {
      "title": "The Travels of Ibn Battuta",
      "genres": [
        "Travel",
        "Adventure"
      ],
      "language": "English",
      "rating": 4.5
    },
    {
      "title": "Pride and Prejudice",
      "genres": [
        "Classics",
        "Fiction",
        "Romance",
        "Literature"
      ],
      "language": "English",
      "rating": 4
    },

  ],
  "offset": 0,
  "limit": 3,
  "total": 5
}

Get documents with GET

This endpoint will be deprecated in the near future. Consider using POST /indexes/{index_uid}/documents/fetch instead.

GET
/indexes/{index_uid}/documents

Get a set of documents.

Using the query parameters offset and limit, you can browse through all your documents.filter must be a string. To create filter expressions use AND or OR.

filter will not work without first explicitly adding attributes to the filterableAttributes list. Learn more about filters in our dedicated guide.

Path parameters

NameTypeDescription
index_uid *Stringuid of the requested index

Query parameters

Query ParameterDefault ValueDescription
offset0Number of documents to skip
limit20Number of documents to return
fields*Document attributes to show (case-sensitive, comma-separated)
filterN/ARefine results based on attributes in the filterableAttributes list
retrieveVectorsfalseReturn document vector data with search result
idsnullReturn documents based on their primary keys

Response

NameTypeDescription
resultsArrayAn array of documents
offsetIntegerNumber of documents skipped
limitIntegerNumber of documents returned
totalIntegerTotal number of documents in the index

Returned document order

/indexes/{index_uid}/documents/fetch and /indexes/{index_uid}/documents responses do not return documents following the order of their primary keys.

Example

curl \
  -X GET 'MEILISEARCH_URL/indexes/movies/documents?limit=2&filter=genres=action'

Response: 200 Ok

{
  "results": [
    {
      "id": 364,
      "title": "Batman Returns",
      "overview": "While Batman deals with a deformed man calling himself the Penguin, an employee of a corrupt businessman transforms into the Catwoman.",
      "genres": [
        "Action",
        "Fantasy"
      ],
      "poster": "https://image.tmdb.org/t/p/w500/jKBjeXM7iBBV9UkUcOXx3m7FSHY.jpg",
      "release_date": 708912000
    },
    {
      "id": 13851,
      "title": " Batman: Gotham Knight",
      "overview": "A collection of key events mark Bruce Wayne's life as he journeys from beginner to Dark Knight.",
      "genres": [
        "Animation",
        "Action",
        "Adventure"
      ],
      "poster": "https://image.tmdb.org/t/p/w500/f3xUrqo7yEiU0guk2Ua3Znqiw6S.jpg",
      "release_date": 1215475200
    }
  ],
  "offset": 0,
  "limit": 2,
  "total": 5403
}

Get one document

GET
/indexes/{index_uid}/documents/{document_id}

Get one document using its unique id.

Path parameters

NameTypeDescription
index_uid *Stringuid of the requested index
document_id *String/IntegerDocument id of the requested document

Query parameters

Query ParameterDefault ValueDescription
fields*Document attributes to show (case-sensitive, comma-separated)
retrieveVectorsfalseReturn document vector data with search result

Example

curl \
  -X GET 'MEILISEARCH_URL/indexes/movies/documents/25684?fields=id,title,poster,release_date'

Response: 200 Ok

{
  "id": 25684,
  "title": "American Ninja 5",
  "poster": "https://image.tmdb.org/t/p/w1280/iuAQVI4mvjI83wnirpD8GVNRVuY.jpg",
  "release_date": "1993-01-01"
}

Add or replace documents

POST
/indexes/{index_uid}/documents

Add an array of documents or replace them if they already exist. If the provided index does not exist, it will be created.

If you send an already existing document (same document id) the whole existing document will be overwritten by the new document. Fields that are no longer present in the new document are removed. For a partial update of the document see the add or update documents endpoint.

This endpoint accepts the following content types:

  • application/json
  • application/x-ndjson
  • text/csv

Path parameters

NameTypeDescription
index_uid *Stringuid of the requested index

Query parameters

Query ParameterDefault ValueDescription
primaryKeynullPrimary key of the index
csvDelimiter","Configure the character separating CSV fields. Must be a string containing one ASCII character.

Configuring csvDelimiter and sending data with a content type other than CSV will cause Meilisearch to throw an error.

If you want to set the primary key of your index on document addition, it can only be done the first time you add documents to the index. After this, the primaryKey parameter will be ignored if given.

Body

An array of documents. Each document is represented as a JSON object.

[
  {
    "id": 287947,
    "title": "Shazam",
    "poster": "https://image.tmdb.org/t/p/w1280/xnopI5Xtky18MPhK40cZAGAOVeV.jpg",
    "overview": "A boy is given the ability to become an adult superhero in times of need with a single magic word.",
    "release_date": "2019-03-23"
  }
]

_vectors

_vectors is a special document attribute containing an object with vector embeddings for AI-powered search.

Each key of the _vectors object must be the name of a configured embedder and correspond to a nested object with two fields, embeddings and regenerate:

[
  {
    "id": 452,
    "title": "Female Trouble",
    "overview": "Delinquent high school student Dawn Davenport runs away from home and embarks upon a life of crime.",
    "_vectors": {
      "default": {
        "embeddings": [0.1, 0.2, 0.3],
        "regenerate": false
      },
      "ollama": {
        "embeddings": [0.4, 0.12, 0.6],
        "regenerate": true
      }
    }
  }
]

embeddings is an optional field. It must be an array of numbers representing a single embedding for that document. It may also be an array of arrays of numbers representing multiple embeddings for that document. embeddings defaults to null.

regenerate is a mandatory field. It must be a Boolean value. If regenerate is true, Meilisearch automatically generates embeddings for that document immediately and every time the document is updated. If regenerate is false, Meilisearch keeps the last value of the embeddings on document updates.

You may also use an array shorthand to add embeddings to a document:

"_vectors": {
  "default": [0.003, 0.1, 0.75]
}

Vector embeddings added with the shorthand are not replaced when Meilisearch generates new embeddings. The above example is equivalent to:

"default": {
  "embeddings": [0.003, 0.1, 0.75],
  "regenerate": false
}

If the key for an embedder inside _vectors is empty or null, Meilisearch treats the document as not having any embeddings for that embedder. This document is then returned last during AI-powered searches.

Example

curl \
  -X POST 'MEILISEARCH_URL/indexes/movies/documents' \
  -H 'Content-Type: application/json' \
  --data-binary '[
    {
      "id": 287947,
      "title": "Shazam",
      "poster": "https://image.tmdb.org/t/p/w1280/xnopI5Xtky18MPhK40cZAGAOVeV.jpg",
      "overview": "A boy is given the ability to become an adult superhero in times of need with a single magic word.",
      "release_date": "2019-03-23"
    }
  ]'

Response: 202 Accepted

{
    "taskUid": 1,
    "indexUid": "movies",
    "status": "enqueued",
    "type": "documentAdditionOrUpdate",
    "enqueuedAt": "2021-08-11T09:25:53.000000Z"
}

You can use this taskUid to get more details on the status of the task.

Add or update documents

PUT
/indexes/{index_uid}/documents

Add a list of documents or update them if they already exist. If the provided index does not exist, it will be created.

If you send an already existing document (same document id) the old document will be only partially updated according to the fields of the new document. Thus, any fields not present in the new document are kept and remain unchanged.

To completely overwrite a document, check out the add or replace documents route.

If you want to set the primary key of your index through this route, you may only do so the first time you add documents to the index. If you try to set the primary key after having added documents to the index, the task will return an error.

This endpoint accepts the following content types:

  • application/json
  • application/x-ndjson
  • text/csv

Path parameters

NameTypeDescription
index_uid *Stringuid of the requested index

Query parameters

Query ParameterDefault ValueDescription
primaryKeynullPrimary key of the documents
csvDelimiter","Configure the character separating CSV fields. Must be a string containing one ASCII character.

Configuring csvDelimiter and sending data with a content type other than CSV will cause Meilisearch to throw an error.

Body

An array of documents. Each document is represented as a JSON object.

[
  {
    "id": 287947,
    "title": "Shazam ⚡️"
  }
]

Example

curl \
  -X PUT 'MEILISEARCH_URL/indexes/movies/documents' \
  -H 'Content-Type: application/json' \
  --data-binary '[
    {
      "id": 287947,
      "title": "Shazam ⚡️",
      "genres": "comedy"
    }
  ]'

This document is an update of the document found in add or replace document.

The documents are matched because they have the same primary key value id: 287947. This route will update the title field as it changed from Shazam to Shazam ⚡️ and add the new genres field to that document. The rest of the document will remain unchanged.

Response: 202 Accepted

{
    "taskUid": 1,
    "indexUid": "movies",
    "status": "enqueued",
    "type": "documentAdditionOrUpdate",
    "enqueuedAt": "2021-08-11T09:25:53.000000Z"
}

You can use this taskUid to get more details on the status of the task.

Update documents with function experimental

POST
/indexes/{index_uid}/documents/edit

Use a RHAI function to edit one or more documents directly in Meilisearch.

This is an experimental feature. Use the experimental features endpoint to activate it:

curl \
  -X PATCH 'MEILISEARCH_URL/experimental-features/' \
  -H 'Content-Type: application/json' \
  --data-binary '{
    "editDocumentsByFunction": true
  }'

Path parameters

NameTypeDescription
index_uid *Stringuid of the requested index

Query parameters

Query ParameterDefault ValueDescription
functionnullA string containing a RHAI function
filternullA string containing a filter expression
contextnullAn object with data Meilisearch should make available for the editing function

function

function must be a string with a RHAI function that Meilisearch will apply to all selected documents. By default this function has access to a single variable, doc, representing the document you are currently editing. This is a required field.

filter

filter must be a string containing a filter expression. Use filter when you want only to apply function to a subset of the documents in your database.

context

Use context to pass data to the function scope. By default a function only has access to the document it is editing.

Example

curl \
-X POST 'MEILISEARCH_URL/indexes/INDEX_NAME/documents/edit' \
-H 'Content-Type: application/json' \
--data-binary '{
  "function": "doc.title = `${doc.title.to_upper()}`"
}'

Delete all documents

DELETE
/indexes/{index_uid}/documents

Delete all documents in the specified index.

Path parameters

NameTypeDescription
index_uid *Stringuid of the requested index

Example

curl \
  -X DELETE 'MEILISEARCH_URL/indexes/movies/documents'

Response: 202 Accepted

{
    "taskUid": 1,
    "indexUid": "movies",
    "status": "enqueued",
    "type": "documentDeletion",
    "enqueuedAt": "2021-08-11T09:25:53.000000Z"
}

You can use this taskUid to get more details on the status of the task.

Delete one document

DELETE
/indexes/{index_uid}/documents/{document_id}

Delete one document based on its unique id.

Path parameters

NameTypeDescription
index_uid *Stringuid of the requested index
document_id *String/IntegerDocument id of the requested document

Example

curl \
  -X DELETE 'MEILISEARCH_URL/indexes/movies/documents/25684'

Response: 202 Accepted

{
    "taskUid": 1,
    "indexUid": "movies",
    "status": "enqueued",
    "type": "documentDeletion",
    "enqueuedAt": "2021-08-11T09:25:53.000000Z"
}

You can use this taskUid to get more details on the status of the task.

Delete documents by filter

POST
/indexes/{index_uid}/documents/delete

Delete a set of documents based on a filter.

Path parameters

NameTypeDescription
index_uid *Stringuid of the requested index

Body

A filter expression written as a string or array of array of strings for the documents to be deleted.

filter will not work without first explicitly adding attributes to the filterableAttributes list. Learn more about filters in our dedicated guide.

 "filter": "rating > 3.5"

Sending an empty payload (--data-binary '{}') will return a bad_request error.

Example

curl \
  -X POST MEILISEARCH_URL/indexes/movies/documents/delete \
  -H 'Content-Type: application/json' \
  --data-binary '{
    "filter": "genres = action OR genres = adventure"
  }'

Response: 202 Accepted

{
    "taskUid": 1,
    "indexUid": "movies",
    "status": "enqueued",
    "type": "documentDeletion",
    "enqueuedAt": "2023-05-15T08:38:48.024551Z"
}

You can use this taskUid to get more details on the status of the task.

Delete documents by batch

This endpoint will be deprecated in the near future. Consider using POST /indexes/{index_uid}/documents/delete instead .

POST
/indexes/{index_uid}/documents/delete-batch

Delete a set of documents based on an array of document ids.

Path parameters

NameTypeDescription
index_uid *Stringuid of the requested index

Body

An array of numbers containing the unique ids of the documents to be deleted.

[23488, 153738, 437035, 363869]

Example

curl \
  -X POST 'MEILISEARCH_URL/indexes/movies/documents/delete-batch' \
  -H 'Content-Type: application/json' \
  --data-binary '[
    23488,
    153738,
    437035,
    363869
  ]'

Response: 202 Accepted

{
    "taskUid": 1,
    "indexUid": "movies",
    "status": "enqueued",
    "type": "documentDeletion",
    "enqueuedAt": "2021-08-11T09:25:53.000000Z"
}

You can use this taskUid to get more details on the status of the task.

Was this page helpful?