pouchdb-adapter-indexeddb

8.0.1 • Public • Published

pouchdb-adapter-indexeddb

PouchDB adapter using IndexedDB as its data store. Designed to run in the browser. Its adapter name is 'indexeddb'.

Usage

npm install pouchdb-adapter-indexeddb
PouchDB.plugin(require('pouchdb-adapter-indexeddb'));
var db = new PouchDB('mydb', {adapter: 'indexeddb'});

For full API documentation and guides on PouchDB, see PouchDB.com. For details on PouchDB sub-packages, see the Custom Builds documentation.

Source

PouchDB and its sub-packages are distributed as a monorepo.

For a full list of packages, see the GitHub source.

Differences between CouchDB and PouchDB's find implementations under IndexedDb

These should be merged into some part of the external PouchDB documentation when this becomes a publicly usable adapter, if it's the default adapter or if it's one you can mix in manually.

PouchDB attempts to be 100% compatible with CouchDB. However, there are some subtle differences you should be aware of between CouchDB and PouchDB running on IndexedDB.

First, note that these differences only exist in the native indexeddb index implementation. You can run an explain query to determine which index you're using. TODO: example.

Data type ordering

In upper bounded ranged queries (e.g, {foo: {$lt: 10}}) the returned order of null, true and false alongside very small integers (Number.MIN_SAFE_INTEGER + 2 and below) may be inconsistent with CouchDB's ordering.

This may be fixed in the future. See:

Object indexing in Mango

CouchDB supports null, booleans, numbers, strings, arrays and objects in its indexes, and ranged queries operate in that order.

Unfortunately IndexedDB does not support objects in indexes. If an object is present on indexed keypath that document will not be present in the index.

This will manifest in two ways:

  • If you are trying to use an object as a key to an index you will not get the correct results
  • If you are doing a lower bounded ranged query (eg. {foo: {$gt: 10}}) objects on this keypath (here foo) will not return their documents.

This is highly unlikely to be fixed in the future by PouchDB, as it would require improvements to IndexedDB. See:

Mango Queries with partial_filter_selector

Mango indexes with a partial_filter_selector are using map-reduce views. Simually to the idb-adabter. All performance gains of native IndexedDB indexes will be lost.

Also ordering is CouchDB combatible.

This fallback is required because IndexedDB indexes only work on all db entries. And not on a subsection.

Readme

Keywords

none

Package Sidebar

Install

npm i pouchdb-adapter-indexeddb

Weekly Downloads

632

Version

8.0.1

License

Apache-2.0

Unpacked Size

117 kB

Total Files

5

Last publish

Collaborators

  • jcoglan
  • albaherreriasdev
  • jan
  • daleharvey
  • pouchdb-user
  • garethbowen
  • garrensmith
  • nolanlawson
  • willholley