{% include anchor.html edit="true" title="Compact the database" hash="compaction" %}
{% highlight js %}
db.compact([options], [callback])
{% endhighlight %}
Triggers a compaction operation in the local or remote database. This reduces the database's size by removing unused and old data, namely non-leaf revisions and attachments that are no longer referenced by those revisions. Note that this is a separate operation from [`viewCleanup()`](#view_cleanup).
For remote databases, PouchDB checks the compaction status at regular intervals and fires the callback (or resolves the promise) upon completion. Consult the [compaction section of CouchDB's maintenance documentation](http://couchdb.readthedocs.org/en/latest/maintenance/compaction.html) for more details.
Also see [auto-compaction](#create_database), which runs compaction automatically (local databases only).
* `options.interval`: Number of milliseconds to wait before asking again if compaction is already done. Defaults to 200. (Only applies to remote databases.)
#### Example Usage:
{% include code/start.html id="compact" type="callback" %}
{% highlight js %}
db.compact(function (err, result) {
if (err) { return console.log(err); }
// handle result
});
{% endhighlight %}
{% include code/end.html %}
{% include code/start.html id="compact" type="async" %}
{% highlight js %}
try {
var result = await db.compact();
} catch (err) {
console.log(err);
}
{% endhighlight %}
{% include code/end.html %}
{% include code/start.html id="compact" type="promise" %}
{% highlight js %}
db.compact().then(function (result) {
// handle result
}).catch(function (err) {
console.log(err);
});
{% endhighlight %}
{% include code/end.html %}
#### Example Response:
{% highlight js %}
{ "ok" : "true" }
{% endhighlight %}