Replace a document
Documents represent a single row or record of data in Astra DB Serverless databases.
You use the Collection
class to work with documents through the Data API clients.
For instructions to get a Collection
object, see Work with collections.
For general information about working with documents, including common operations and operators, see the Work with documents.
For more information about the Data API and clients, see Get started with the Data API.
Replace a document
Find one document that matches a filter condition, and then replace it with a new document.
replaceOne
is similar to findOneAndReplace
, except that the response includes only the result of the operation.
The response doesn’t include a document
object, and the request doesn’t support response-related parameters, such as projection
or returnDocument
.
Sort and filter clauses can use only indexed fields. If you apply selective indexing when you create a collection, you can’t reference non-indexed fields in sort or filter queries. |
-
Python
-
TypeScript
-
Java
-
curl
For more information, see the Client reference.
Find a document matching a filter condition, and then replace the matching document with the given replacement:
replace_result = collection.replace_one(
{"Marco": {"$exists": True}}, # filter
{"Buda": "Pest"}, # replacement
)
Locate and replace a document or create a new one if no match is found:
replace_result = collection.replace_one(
{"Marco": {"$exists": True}},
{"Buda": "Pest"},
upsert=True,
)
Locate and replace the document most similar to a query vector from either $vector
or $vectorize
.
In this example, the filter object is empty, and only the sort object is used to locate the document to replace.
Including the empty filter object ensures that the replacement object is read correctly.
collection.replace_one(
{}, # empty filter
{"name": "Zoo", "desc": "the new best match"}, # replacement
sort={"$vector": [0.1, 0.2, 0.3]}, # sort object, to locate the document to replace
)
Parameters:
Name | Type | Summary | ||
---|---|---|---|---|
|
|
A predicate expressed as a dictionary according to the Data API filter syntax.
For example: |
||
|
|
The new document to write into the collection.
Define all fields that the replacement document must include, except for the
|
||
|
|
See Find a document and Sort clauses. |
||
|
|
This parameter controls the behavior if there are no matches.
If true and there are no matches, then the operation inserts the |
||
|
|
A timeout, in milliseconds, for the underlying HTTP request. This method uses the collection-level timeout by default. |
Returns:
UpdateResult
- An object representing the response from the database after the replace operation. It includes information about the operation.
Example response
UpdateResult(update_info={'n': 1, 'updatedExisting': True, 'ok': 1.0, 'nModified': 1}, raw_results=...)
Example:
from astrapy import DataAPIClient
client = DataAPIClient("TOKEN")
database = client.get_database("API_ENDPOINT")
collection = database.my_collection
collection.insert_one({"Marco": "Polo"})
collection.replace_one({"Marco": {"$exists": True}}, {"Buda": "Pest"})
# prints: UpdateResult(update_info={'n': 1, 'updatedExisting': True, 'ok': 1.0, 'nModified': 1}, raw_results=...)
collection.find_one({"Buda": "Pest"})
# prints: {'_id': '8424905a-...', 'Buda': 'Pest'}
collection.replace_one({"Mirco": {"$exists": True}}, {"Oh": "yeah?"})
# prints: UpdateResult(update_info={'n': 0, 'updatedExisting': False, 'ok': 1.0, 'nModified': 0}, raw_results=...)
collection.replace_one({"Mirco": {"$exists": True}}, {"Oh": "yeah?"}, upsert=True)
# prints: UpdateResult(update_info={'n': 1, 'updatedExisting': False, 'ok': 1.0, 'nModified': 0, 'upserted': '931b47d6-...'}, raw_results=...)
For more information, see the Client reference.
Find a document matching a filter condition, and then replace the matching document with the given replacement:
const result = await collection.replaceOne(
{ 'Marco': 'Polo' }, // filter
{ 'Buda': 'Pest' }, // replacement
);
Locate and replace a document or create a new one if no match is found:
const result = await collection.replaceOne(
{ 'Marco': 'Polo' },
{ 'Buda': 'Pest' },
{ upsert: true },
);
Locate and replace the document most similar to a query vector from either $vector
or $vectorize
.
In this example, the filter object is empty, and only the sort object is used to locate the document to replace.
Including the empty filter object ensures that the replacement object is read correctly.
const result = await collection.replaceOne(
{}, // empty filter
{ name: "Zoe", desc: "The new best match" }, // replacement
{ sort: { $vector: [0.1, 0.2, 0.3] } }, // sort object, to locate the document to replace
);
Parameters:
Name | Type | Summary | ||
---|---|---|---|---|
|
A filter to select the document to replace. For a list of available operators, see Data API operators. For additional examples, see Find documents using filter clauses. |
|||
|
The new document to write into the collection.
Define all fields that the replacement document must include, except for the
|
|||
|
The options for this operation. |
Options (ReplaceOneOptions
):
Name | Type | Summary |
---|---|---|
|
This parameter controls the behavior if there are no matches.
If true and there are no matches, then the operation inserts the |
|
See Find a document and Sort clauses. |
||
|
The maximum time in milliseconds that the client should wait for the operation to complete each underlying HTTP request. |
Returns:
Promise<ReplaceOneResult<Schema>>
- The result of the
replacement operation.
Example:
import { DataAPIClient } from '@datastax/astra-db-ts';
// Reference an untyped collection
const client = new DataAPIClient('TOKEN');
const db = client.db('ENDPOINT', { keyspace: 'KEYSPACE' });
const collection = db.collection('COLLECTION');
(async function () {
// Insert some document
await collection.insertOne({ 'Marco': 'Polo' });
// { modifiedCount: 1, matchedCount: 1, upsertedCount: 0 }
await collection.replaceOne(
{ 'Marco': { '$exists': true } },
{ 'Buda': 'Pest' }
);
// { _id: '3756ce75-aaf1-430d-96ce-75aaf1730dd3', Buda: 'Pest' }
await collection.findOne({ 'Buda': 'Pest' });
// { modifiedCount: 0, matchedCount: 0, upsertedCount: 0 }
await collection.replaceOne(
{ 'Mirco': { '$exists': true } },
{ 'Oh': 'yeah?' }
);
// { modifiedCount: 0, matchedCount: 0, upsertedId: '...', upsertedCount: 1 }
await collection.replaceOne(
{ 'Mirco': { '$exists': true } },
{ 'Oh': 'yeah?' },
{ upsert: true }
);
})();
Operations on documents are performed at the Collection
level.
Collection is a generic class with the default type of Document
.
You can specify your own type, and the object is serialized by Jackson.
For more information, see the Client reference.
Most methods have synchronous and asynchronous flavors, where the asynchronous version is suffixed by Async
and returns a CompletableFuture
:
// Synchronous
UpdateResult replaceOne(Filter filter, T replacement);
UpdateResult replaceOne(Filter filter, T replacement, ReplaceOneOptions options);
// Asynchronous
CompletableFuture<UpdateResult> replaceOneAsync(Filter filter, T replacement);
CompletableFuture<UpdateResult> replaceOneAsync(Filter filter, T replacement, ReplaceOneOptions options);
Parameters:
Name | Type | Summary | ||
---|---|---|---|---|
|
|
Filter criteria to find the document to replace.
The filter is a JSON object that can contain any valid Data API filter expression.
For a list of available operators, see Data API operators.
For examples and options, including |
||
|
|
The new document to write into the collection.
Define all fields that the replacement document must include, except for the
|
||
|
Set the different options for the
|
Returns:
UpdateResult - Return a wrapper object with the result of the operation.
The object contains the number of documents matched (matchedCount
) and updated (modifiedCount
).
Example:
package com.datastax.astra.client.collection;
import com.datastax.astra.client.Collection;
import com.datastax.astra.client.DataAPIClient;
import com.datastax.astra.client.model.Document;
import com.datastax.astra.client.model.Filter;
import com.datastax.astra.client.model.Filters;
import com.datastax.astra.client.model.FindOneAndReplaceOptions;
import com.datastax.astra.client.model.Projections;
import com.datastax.astra.client.model.Sorts;
import java.util.Optional;
import static com.datastax.astra.client.model.Filters.lt;
public class FindOneAndReplace {
public static void main(String[] args) {
Collection<Document> collection = new DataAPIClient("TOKEN")
.getDatabase("API_ENDPOINT")
.getCollection("COLLECTION_NAME");
// Building a filter
Filter filter = Filters.and(
Filters.gt("field2", 10),
lt("field3", 20),
Filters.eq("field4", "value"));
FindOneAndReplaceOptions options = new FindOneAndReplaceOptions()
.projection(Projections.include("field1"))
.sort(Sorts.ascending("field1"))
.upsert(true)
.returnDocumentAfter();
Document docForReplacement = new Document()
.append("field1", "value1")
.append("field2", 20)
.append("field3", 30)
.append("field4", "value4");
// It will return the document before deleting it
Optional<Document> docBeforeReplace = collection
.findOneAndReplace(filter, docForReplacement, options);
}
}
This operation has no literal equivalent in HTTP.
Instead, you can use [find-and-replace-a-document] with "projection": {"*": false}
, which excludes all document
fields from the response.