Package com.mongodb
Class WriteConcern
- java.lang.Object
- 
- com.mongodb.WriteConcern
 
- 
- All Implemented Interfaces:
- Serializable
 
 @Immutable public class WriteConcern extends Object implements Serializable Controls the acknowledgment of write operations with various options. w- 0: Don't wait for acknowledgement from the server
- 1: Wait for acknowledgement, but don't wait for secondaries to replicate
- >=2: Wait for one or more secondaries to also acknowledge
- "majority": Wait for a majority of data bearing nodes to acknowledge
- "<tag set name>": Wait for one or more secondaries to also acknowledge based on a tag set name
 wtimeout- how long to wait for secondaries to acknowledge before failing- 0: indefinite
- >0: time to wait in milliseconds
 Other options: - journal: If true block until write operations have been committed to the journal. Cannot be used in combination with- fsync. Write operations will fail with an exception if this option is used when the server is running without journaling.
 - See Also:
- Serialized Form
- MongoDB documentation
- Write Concern
- Write Concern Reference
 
- 
- 
Field SummaryFields Modifier and Type Field Description static WriteConcernACKNOWLEDGEDWrite operations that use this write concern will wait for acknowledgement, using the default write concern configured on the server.static WriteConcernJOURNALEDWrite operations wait for the server to group commit to the journal file on disk.static WriteConcernMAJORITYExceptions are raised for network issues, and server errors; waits on a majority of servers for the write operation.static WriteConcernUNACKNOWLEDGEDWrite operations that use this write concern will return as soon as the message is written to the socket.static WriteConcernW1Write operations that use this write concern will wait for acknowledgement from a single member.static WriteConcernW2Write operations that use this write concern will wait for acknowledgement from two members.static WriteConcernW3Write operations that use this write concern will wait for acknowledgement from three members.
 - 
Constructor SummaryConstructors Constructor Description WriteConcern(int w)Construct an instance with the given integer-based value for w.WriteConcern(int w, int wTimeoutMS)Constructs an instance with the given integer-based value for w and the given value for wTimeoutMS.WriteConcern(String w)Construct an instance with the given tag set-based value for w.
 - 
Method SummaryAll Methods Static Methods Instance Methods Concrete Methods Modifier and Type Method Description BsonDocumentasDocument()Gets this write concern as a document.booleanequals(Object o)BooleangetJournal()Gets the journal property.intgetW()Gets the w value as an integer.ObjectgetWObject()Gets the w value.StringgetWString()Gets the w parameter as a String.IntegergetWTimeout(TimeUnit timeUnit)Gets the wTimeout in the given time unit.inthashCode()booleanisAcknowledged()Returns true if this write concern indicates that write operations must be acknowledged.booleanisServerDefault()Gets whether this write concern indicates that the server's default write concern will be used.StringtoString()static WriteConcernvalueOf(String name)Gets the WriteConcern constants by name (matching is done case insensitively).WriteConcernwithJournal(Boolean journal)Constructs a new WriteConcern from the current one and the specified journal valueWriteConcernwithW(int w)Constructs a new WriteConcern from the current one and the specified integer-based value for wWriteConcernwithW(String w)Constructs a new WriteConcern from the current one and the specified tag-set based value for wWriteConcernwithWTimeout(long wTimeout, TimeUnit timeUnit)Constructs a new WriteConcern from the current one and the specified wTimeout in the given time unit.
 
- 
- 
- 
Field Detail- 
ACKNOWLEDGEDpublic static final WriteConcern ACKNOWLEDGED Write operations that use this write concern will wait for acknowledgement, using the default write concern configured on the server.- Since:
- 2.10.0
- MongoDB documentation
- Acknowledged
 
 - 
W1public static final WriteConcern W1 Write operations that use this write concern will wait for acknowledgement from a single member.- Since:
- 3.2
- MongoDB documentation
- w option
 
 - 
W2public static final WriteConcern W2 Write operations that use this write concern will wait for acknowledgement from two members.- Since:
- 3.2
- MongoDB documentation
- w option
 
 - 
W3public static final WriteConcern W3 Write operations that use this write concern will wait for acknowledgement from three members.- Since:
- 3.2
- MongoDB documentation
- w option
 
 - 
UNACKNOWLEDGEDpublic static final WriteConcern UNACKNOWLEDGED Write operations that use this write concern will return as soon as the message is written to the socket. Exceptions are raised for network issues, but not server errors.- Since:
- 2.10.0
- MongoDB documentation
- Unacknowledged
 
 - 
JOURNALEDpublic static final WriteConcern JOURNALED Write operations wait for the server to group commit to the journal file on disk.- MongoDB documentation
- Journaled
 
 - 
MAJORITYpublic static final WriteConcern MAJORITY Exceptions are raised for network issues, and server errors; waits on a majority of servers for the write operation.
 
- 
 - 
Constructor Detail- 
WriteConcernpublic WriteConcern(int w) Construct an instance with the given integer-based value for w.- Parameters:
- w- number of servers to ensure write propagation to before acknowledgment, which must be- >= 0
- MongoDB documentation
- w option
 
 - 
WriteConcernpublic WriteConcern(String w) Construct an instance with the given tag set-based value for w.
 - 
WriteConcernpublic WriteConcern(int w, int wTimeoutMS)Constructs an instance with the given integer-based value for w and the given value for wTimeoutMS.- Parameters:
- w- the w value, which must be >= 0
- wTimeoutMS- the wTimeout in milliseconds, which must be >= 0
- MongoDB documentation
- w option
- wtimeout option
 
 
- 
 - 
Method Detail- 
getWObjectpublic Object getWObject() Gets the w value.- Returns:
- w, either an instance of Integer or String or null
 
 - 
getWpublic int getW() Gets the w value as an integer.- Returns:
- w as an int
- Throws:
- IllegalStateException- if w is null or not an integer
 
 - 
getWStringpublic String getWString() Gets the w parameter as a String.- Returns:
- w as a String
- Throws:
- IllegalStateException- if w is null or not a String
 
 - 
getWTimeout@Nullable public Integer getWTimeout(TimeUnit timeUnit) Gets the wTimeout in the given time unit.- Parameters:
- timeUnit- the non-null time unit for the result
- Returns:
- the WTimeout, which may be null if a wTimeout has not been specified
- Since:
- 3.2
- MongoDB documentation
- wTimeout
 
 - 
getJournalpublic Boolean getJournal() Gets the journal property. The default value is null.- Returns:
- whether journal syncing is enabled, or null if unspecified.
- Since:
- 3.2
- MongoDB documentation
- Journaled
 
 - 
isServerDefaultpublic boolean isServerDefault() Gets whether this write concern indicates that the server's default write concern will be used.- Returns:
- true if this write concern indicates that the server's default write concern will be used
- MongoDB documentation
- getLastErrorDefaults
 
 - 
asDocumentpublic BsonDocument asDocument() Gets this write concern as a document.- Returns:
- The write concern as a BsonDocument, even if w <= 0
 
 - 
isAcknowledgedpublic boolean isAcknowledged() Returns true if this write concern indicates that write operations must be acknowledged.- Returns:
- true w != null or w > 0 or journal is true or fsync is true
- MongoDB documentation
- Acknowledged
 
 - 
valueOfpublic static WriteConcern valueOf(String name) Gets the WriteConcern constants by name (matching is done case insensitively).- Parameters:
- name- the name of the WriteConcern
- Returns:
- the WriteConcern instance
 
 - 
withWpublic WriteConcern withW(int w) Constructs a new WriteConcern from the current one and the specified integer-based value for w- Parameters:
- w- number of servers to ensure write propagation to before acknowledgment, which must be- >= 0
- Returns:
- the new WriteConcern
- MongoDB documentation
- Replica Acknowledged
 
 - 
withWpublic WriteConcern withW(String w) Constructs a new WriteConcern from the current one and the specified tag-set based value for w- Parameters:
- w- tag set, or "majority", representing the servers to ensure write propagation to before acknowledgment. Do not use string representation of integer values for w
- Returns:
- the new WriteConcern
- See Also:
- withW(int)
- MongoDB documentation
- Tag Sets
 
 - 
withJournalpublic WriteConcern withJournal(Boolean journal) Constructs a new WriteConcern from the current one and the specified journal value- Parameters:
- journal- true if journalling is required for acknowledgement, false if not, or null if unspecified
- Returns:
- the new WriteConcern
- Since:
- 3.2
- MongoDB documentation
- j option
 
 - 
withWTimeoutpublic WriteConcern withWTimeout(long wTimeout, TimeUnit timeUnit) Constructs a new WriteConcern from the current one and the specified wTimeout in the given time unit.- Parameters:
- wTimeout- the wTimeout, which must be >= 0 and <= Integer.MAX_VALUE after conversion to milliseconds
- timeUnit- the non-null time unit to apply to wTimeout
- Returns:
- the WriteConcern with the given wTimeout
- Since:
- 3.2
- MongoDB documentation
- wtimeout option
 
 
- 
 
-