DocumentMutation.setOrReplace()
Either creates a field in a document and gives the field the specified value, or replaces the value of a field that already exists in a document.
Operations Performed
- If the field exists, changes its value to the specified value, even if the data type of the specified value differs from the data type of the current value.
- If the field does not exist, creates the field and gives it the specified value.
Example of Setting and Replacing Scalar Values
- Original document
-
{ "_id" : "000001", "a" : { "b" : 1 } }
- Example code for the set
-
public DocumentMutation buildDocumentMutation() { return MapRDB.newDocumentMutation() .setOrReplace("a", ImmutableMap.of( "b", "newString", "c", 2)); } public void update(String tablePath, DocumentMutation mutation, String _id) { try(Table table = MapRDB.getTable(tablePath)) { table.update(_id, mutation); } }
Parameter Description _id
The value of the document's _id
field.tablePath
The path of the table in the MapR file system. See Table Paths. - Revised document
-
{ "_id" : "000001", "a" : { "b" : "newString", "c" : 2 } }
Permissions Required
- The
readAce
andwriteAce
permissions on the volumes where the JSON tables that contain the documents are located. For information about how to set permissions on volumes, see Setting/Modifying Whole Volume ACEs. writeperm
on the field, if it exists. See How to Obtainreadperm
orwriteperm
on a Field.readperm
andwriteperm
on the field, if it exists and contains an array. See How to Obtainreadperm
andwriteperm
on a Field.writeperm
on the parent field, if the specified field does not exist. See How to Obtainreadperm
orwriteperm
on a Field.
Link to Javadoc
DocumentMutation
object modifies a field two or
more times, only the final operation on that field is applied.Example One
table.update()
in the last line fails with error code
22:
DBDocument doc = MapRDB.newDocument()
.set("int", 100)
.set("date", new Date(1000))
.set("string", "a string");
table.insertOrReplace("doc1", doc);
// Set different fields
DocumentMutation mutation = MapRDB.newDocumentMutation();
mutation.setOrReplace("string", 1000);
mutation.set("string", 2000);
table.update("doc1", mutation);
Example Two
This code results in the document {"string":"a string
add3"}
, rather than the document {"string":"a string add1 add2
add3"}
.
DBDocument doc = MapRDB.newDocument()
.set("string", "a string");
table.insertOrReplace("doc1", record);
DocumentMutation mutation = MapRDB.newDocumentMutation();
mutation.append("string", " add1");
mutation.append("string", " add2");
mutation.append("string", " add3");
table.update("doc1", mutation);