{% include anchor.html edit="true" title="Create/update a document" hash="create_document" %} ### Using db.put() {% highlight js %} db.put(doc, [options], [callback]) {% endhighlight %} Create a new document or update an existing document. If the document already exists, you must specify its revision `_rev`, otherwise a conflict will occur. There are some [restrictions on valid property names of the documents](http://wiki.apache.org/couchdb/HTTP_Document_API#Special_Fields). If you try to store non-JSON data (for instance `Date` objects) you may see [inconsistent results](http://pouchdb.com/errors.html#could_not_be_cloned). #### Example Usage: Create a new doc with an `_id` of `'mydoc'`: {% include code/start.html id="newDoc" type="callback" %} {% highlight js %} db.put({ _id: 'mydoc', title: 'Heroes' }, function(err, response) { if (err) { return console.log(err); } // handle response }); {% endhighlight %} {% include code/end.html %} {% include code/start.html id="newDoc" type="async" %} {% highlight js %} try { var response = await db.put({ _id: 'mydoc', title: 'Heroes' }); } catch (err) { console.log(err); } {% endhighlight %} {% include code/end.html %} {% include code/start.html id="newDoc" type="promise" %} {% highlight js %} db.put({ _id: 'mydoc', title: 'Heroes' }).then(function (response) { // handle response }).catch(function (err) { console.log(err); }); {% endhighlight %} {% include code/end.html %} You can update an existing doc using `_rev`: {% include code/start.html id="updateDoc" type="callback" %} {% highlight js %} db.get('mydoc', function(err, doc) { if (err) { return console.log(err); } db.put({ _id: 'mydoc', _rev: doc._rev, title: "Let's Dance" }, function(err, response) { if (err) { return console.log(err); } // handle response }); }); {% endhighlight %} {% include code/end.html %} {% include code/start.html id="updateDoc" type="async" %} {% highlight js %} try { var doc = await db.get('mydoc'); var response = await db.put({ _id: 'mydoc', _rev: doc._rev, title: "Let's Dance" }); } catch (err) { console.log(err); } {% endhighlight %} {% include code/end.html %} {% include code/start.html id="updateDoc" type="promise" %} {% highlight js %} db.get('mydoc').then(function(doc) { return db.put({ _id: 'mydoc', _rev: doc._rev, title: "Let's Dance" }); }).then(function(response) { // handle response }).catch(function (err) { console.log(err); }); {% endhighlight %} {% include code/end.html %} #### Example Response: {% highlight js %} { "ok": true, "id": "mydoc", "rev": "1-A6157A5EA545C99B00FF904EEF05FD9F" } {% endhighlight %} The response contains the `id` of the document, the new `rev`, and an `ok` to reassure you that everything is okay. ### Using db.post() {% highlight js %} db.post(doc, [options], [callback]) {% endhighlight %} Create a new document and let PouchDB auto-generate an `_id` for it. #### Example Usage: {% include code/start.html id="post_doc" type="callback" %} {% highlight js %} db.post({ title: 'Ziggy Stardust' }, function (err, response) { if (err) { return console.log(err); } // handle response }); {% endhighlight %} {% include code/end.html %} {% include code/start.html id="post_doc" type="async" %} {% highlight js %} try { var response = await db.post({ title: 'Ziggy Stardust' }); } catch (err) { console.log(err); } {% endhighlight %} {% include code/end.html %} {% include code/start.html id="post_doc" type="promise" %} {% highlight js %} db.post({ title: 'Ziggy Stardust' }).then(function (response) { // handle response }).catch(function (err) { console.log(err); }); {% endhighlight %} {% include code/end.html %} #### Example Response: {% highlight js %} { "ok" : true, "id" : "8A2C3761-FFD5-4770-9B8C-38C33CED300A", "rev" : "1-d3a8e0e5aa7c8fff0c376dac2d8a4007" } {% endhighlight %} **Put vs. post**: The basic rule of thumb is: `put()` new documents with an `_id`, `post()` new documents without an `_id`. You should also prefer `put()` to `post()`, because when you `post()`, you are missing an opportunity to use `allDocs()` to sort documents by `_id` (because your `_id`s are random). For more info, read the [PouchDB pro tips](/2014/06/17/12-pro-tips-for-better-code-with-pouchdb.html).