[[create-doc]] === Creating a New Document
How can we be sure, when we index a document, that((("documents", "creating"))) we are creating an entirely new document and not overwriting an existing one?
Remember that the combination of _index
, _type
, and _id
uniquely
identifies a document. So the easiest way to ensure that our document is new
is by letting Elasticsearch autogenerate a new unique _id
, using the POST
version of ((("POST method")))((("HTTP methods", "POST")))the index request:
POST /website/blog/
However, if we already have an _id
that we want to use, then we have to tell
Elasticsearch that it should accept our index request only if a document with
the same _index
, _type
, and _id
doesn't exist already. There are two ways
of doing this, both of which amount to the same thing. Use whichever method is
more convenient for you.
The first method uses the op_type
query((("PUT method")))((("HTTP methods", "PUT")))((("query strings", "op_type parameter")))((("op_type query string parameter")))-string parameter:
PUT /website/blog/123?op_type=create
And the second uses the /_create
endpoint in the URL:
PUT /website/blog/123/_create
If the request succeeds in creating a new document, Elasticsearch will
return the usual metadata and an HTTP response code of 201 Created
.
On the other hand, if a document ((("Document Already Exists Exception")))with the same _index
, _type
, and _id
already exists, Elasticsearch will respond with a 409 Conflict
response
code, and an error message like the following:
{ "error" : "DocumentAlreadyExistsException[[website][4] [blog][123]: document already exists]", "status" : 409
// SENSE: 030_Data/30_Create_doc.json