| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266 | [[java-rest-high-document-update]]=== Update API[[java-rest-high-document-update-request]]==== Update RequestAn `UpdateRequest` requires the following arguments:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request]--------------------------------------------------<1> Index<2> Type<3> Document idThe Update API allows to update an existing document by using a scriptor by passing a partial document.==== Updates with a scriptThe script can be provided as an inline script:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-with-inline-script]--------------------------------------------------<1> Script parameters provided as a `Map` of objects<2> Create an inline script using the `painless` language and the previous parameters<3> Sets the script to the update requestOr as a stored script:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-with-stored-script]--------------------------------------------------<1> Reference to a script stored under the name `increment-field` in the `painless` language<2> Sets the script in the update request==== Updates with a partial documentWhen using updates with a partial document, the partial document will be merged with theexisting document.The partial document can be provided in different ways:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-with-doc-as-string]--------------------------------------------------<1> Partial document source provided as a `String` in JSON format["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-with-doc-as-map]--------------------------------------------------<1> Partial document source provided as a `Map` which gets automatically convertedto JSON format["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-with-doc-as-xcontent]--------------------------------------------------<1> Partial document source provided as an `XContentBuilder` object, the Elasticsearchbuilt-in helpers to generate JSON content["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-shortcut]--------------------------------------------------<1> Partial document source provided as `Object` key-pairs, which gets converted toJSON format==== UpsertsIf the document does not already exist, it is possible to define some content thatwill be inserted as a new document using the `upsert` method:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-upsert]--------------------------------------------------<1> Upsert document source provided as a `String`Similarly to the partial document updates, the content of the `upsert` documentcan be defined using methods that accept `String`, `Map`, `XContentBuilder` or`Object` key-pairs.==== Optional argumentsThe following arguments can optionally be provided:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-routing]--------------------------------------------------<1> Routing value["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-timeout]--------------------------------------------------<1> Timeout to wait for primary shard to become available as a `TimeValue`<2> Timeout to wait for primary shard to become available as a `String`["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-refresh]--------------------------------------------------<1> Refresh policy as a `WriteRequest.RefreshPolicy` instance<2> Refresh policy as a `String`["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-retry]--------------------------------------------------<1> How many times to retry the update operation if the document to update hasbeen changed by another operation between the get and indexing phases of theupdate operation["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-no-source]--------------------------------------------------<1> Enable source retrieval, disabled by default["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-source-include]--------------------------------------------------<1> Configure source inclusion for specific fields["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-source-exclude]--------------------------------------------------<1> Configure source exclusion for specific fields["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-version]--------------------------------------------------<1> Version["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-detect-noop]--------------------------------------------------<1> Disable the noop detection["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-scripted-upsert]--------------------------------------------------<1> Indicate that the script must run regardless of whether the document exists or not,ie the script takes care of creating the document if it does not already exist.["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-doc-upsert]--------------------------------------------------<1> Indicate that the partial document must be used as the upsert document if itdoes not exist yet.["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-request-active-shards]--------------------------------------------------<1> Sets the number of shard copies that must be active before proceeding withthe update operation.<2> Number of shard copies provided as a `ActiveShardCount`: can be `ActiveShardCount.ALL`,`ActiveShardCount.ONE` or `ActiveShardCount.DEFAULT` (default)[[java-rest-high-document-update-sync]]==== Synchronous Execution["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-execute]--------------------------------------------------[[java-rest-high-document-update-async]]==== Asynchronous ExecutionThe asynchronous execution of an update request requires both the `UpdateRequest`instance and an `ActionListener` instance to be passed to the asynchronousmethod:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-execute-async]--------------------------------------------------<1> The `UpdateRequest` to execute and the `ActionListener` to use whenthe execution completesThe asynchronous method does not block and returns immediately. Once it iscompleted the `ActionListener` is called back using the `onResponse` methodif the execution successfully completed or using the `onFailure` method ifit failed.A typical listener for `UpdateResponse` looks like:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-execute-listener]--------------------------------------------------<1> Called when the execution is successfully completed. The response isprovided as an argument.<2> Called in case of failure. The raised exception is provided as an argument.[[java-rest-high-document-update-response]]==== Update ResponseThe returned `UpdateResponse` allows to retrieve information about the executed operation as follows:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-response]--------------------------------------------------<1> Handle the case where the document was created for the first time (upsert)<2> Handle the case where the document was updated<3> Handle the case where the document was deleted<4> Handle the case where the document was not impacted by the update,ie no operation (noop) was executed on the documentWhen the source retrieval is enabled in the `UpdateRequest`through the fetchSource method, the response contains thesource of the updated document:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-getresult]--------------------------------------------------<1> Retrieve the updated document as a `GetResult`<2> Retrieve the source of the updated document as a `String`<3> Retrieve the source of the updated document as a `Map<String, Object>`<4> Retrieve the source of the updated document as a `byte[]`<5> Handle the scenario where the source of the document is not present inthe response (this is the case by default)It is also possible to check for shard failures:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-failure]--------------------------------------------------<1> Handle the situation where number of successful shards is less thantotal shards<2> Handle the potential failuresWhen a `UpdateRequest` is performed against a document that does not exist,the response has `404` status code, an `ElasticsearchException` gets thrownwhich needs to be handled as follows:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-docnotfound]--------------------------------------------------<1> Handle the exception thrown because the document not existIf there is a version conflict, an `ElasticsearchException` willbe thrown:["source","java",subs="attributes,callouts,macros"]--------------------------------------------------include-tagged::{doc-tests}/CRUDDocumentationIT.java[update-conflict]--------------------------------------------------<1> The raised exception indicates that a version conflict error was returned.
 |