This is the Third Edition of Indexed Database API. The First Edition , simply titled "Indexed Database API", became a W3C Recommendation on 8 January 2015. The Second Edition , titled "Indexed Database API 2.0", became a W3C Recommendation on 30 January 2018.
Indexed Database API 3.0 is intended to supersede Indexed Database API 2.0.
1. Introduction
User agents need to store large numbers of objects locally in order to satisfy off-line data requirements of Web applications. [WEBSTORAGE] is useful for storing pairs of keys and their corresponding values. However, it does not provide in-order retrieval of keys, efficient searching over values, or storage of duplicate values for a key.
This specification provides a concrete API to perform advanced key-value data management that is at the heart of most sophisticated query processors. It does so by using transactional databases to store keys and their corresponding values (one or more per key), and providing a means of traversing keys in a deterministic order. This is often implemented through the use of persistent B-tree data structures that are considered efficient for insertion and deletion as well as in-order traversal of very large numbers of data records.
2. Constructs
A
name
is
a
string
equivalent
to
a
DOMString
;
that
is,
an
arbitrary
sequence
of
16-bit
code
units
of
any
length,
including
the
empty
string.
Names
are
always
compared
as
opaque
sequences
of
16-bit
code
units.
To create a sorted name list from a list names , run these steps:
- 
Let sorted be names sorted in ascending order with the code unit less than algorithm. 
- 
Return a new DOMStringListassociated with sorted .
Details
This matches the Array.prototype.sort on an Array of Strings . This ordering compares the 16-bit code units in each string, producing a highly efficient, consistent, and deterministic sort order. The resulting list will not match any particular alphabet or lexicographical order, particularly for code points represented by a surrogate pair.2.1. Database
Each origin has an associated set of databases . A database has zero or more object stores which hold the data stored in the database.
A database has a name which identifies it within a specific origin . The name is a name , and stays constant for the lifetime of the database.
A database has a version . When a database is first created, its version is 0 (zero).
A database has at most one associated upgrade transaction , which is either null or an upgrade transaction , and is initially null.
2.1.1. Database connection
Script does not interact with databases directly. Instead, script has indirect access via a connection . A connection object can be used to manipulate the objects of that database . It is also the only way to obtain a transaction for that database .
The act of opening a database creates a connection . There may be multiple connections to a given database at any given time.
A connection can only access databases associated with the origin of the global scope from which the connection is opened.
A connection has a version , which is set when the connection is created. It remains constant for the lifetime of the connection unless an upgrade is aborted , in which case it is set to the previous version of the database . Once the connection is closed the version does not change.
Each connection has a close pending flag which is initially false.
When a connection is initially created it is in an opened state. The connection can be closed through several means. If the execution context where the connection was created is destroyed (for example due to the user navigating away from that page), the connection is closed. The connection can also be closed explicitly using the steps to close a database connection . When the connection is closed its close pending flag is always set to true if it hasn’t already been.
A connection may be closed by a user agent in exceptional circumstances, for example due to loss of access to the file system, a permission change, or clearing of the origin’s storage. If this occurs the user agent must run close a database connection with the connection and with the forced flag set to true.
A connection has an object store set , which is initialized to the set of object stores in the associated database when the connection is created. The contents of the set will remain constant except when an upgrade transaction is running.
A connection 's get the parent algorithm returns null.
A
versionchange
will
be
fired
at
an
open
connection
if
an
attempt
is
made
to
upgrade
or
delete
the
database
.
This
gives
the
connection
the
opportunity
to
close
to
allow
the
upgrade
or
delete
to
proceed.
2.2. Object store
An object store is the primary storage mechanism for storing data in a database .
Each
database
has
a
set
of
object
stores
.
The
set
of
object
stores
can
be
changed,
but
only
using
an
upgrade
transaction
,
i.e.
in
response
to
an
upgradeneeded
event.
When
a
new
database
is
created
it
doesn’t
contain
any
object
stores
.
An object store has a list of records which hold the data stored in the object store. Each record consists of a key and a value . The list is sorted according to key in ascending order. There can never be multiple records in a given object store with the same key.
An object store has a name , which is a name . At any one time, the name is unique within the database to which it belongs.
An object store optionally has a key path . If the object store has a key path it is said to use in-line keys . Otherwise it is said to use out-of-line keys .
An object store optionally has a key generator .
An object store can derive a key for a record from one of three sources:
- 
A key generator . A key generator generates a monotonically increasing numbers every time a key is needed. 
- 
Keys can be derived via a key path . 
- 
Keys can also be explicitly specified when a value is stored in the object store. 
2.2.1. Object store handle
Script does not interact with object stores directly. Instead, within a transaction , script has indirect access via an object store handle .
An object store handle has an associated object store and an associated transaction . Multiple handles may be associated with the same object store in different transactions , but there must be only one object store handle associated with a particular object store within a transaction .
An object store handle has an index set , which is initialized to the set of indexes that reference the associated object store when the object store handle is created. The contents of the set will remain constant except when an upgrade transaction is running.
An object store handle has a name , which is initialized to the name of the associated object store when the object store handle is created. The name will remain constant except when an upgrade transaction is running.
2.3. Values
Each
record
is
associated
with
a
value
.
User
agents
must
support
any
serializable
object
.
This
includes
simple
types
such
as
String
primitive
values
and
Date
objects
as
well
as
Object
and
Array
instances,
File
objects,
Blob
objects,
ImageData
objects,
and
so
on.
Record
values
are
stored
and
retrieved
by
value
rather
than
by
reference;
later
changes
to
a
value
have
no
effect
on
the
record
stored
in
the
database.
Record values are Records output by the StructuredSerializeForStorage operation.
2.4. Keys
In order to efficiently retrieve records stored in an indexed database, each record is organized according to its key .
A key has an associated type which is one of: number , date , string , binary , or array .
A
key
also
has
an
associated
value
,
which
will
be
either:
an
unrestricted
double
if
type
is
number
or
date
,
a
DOMString
if
type
is
string
,
a
byte
sequence
if
type
is
binary
,
or
a
list
of
other
keys
if
type
is
array
.
An ECMAScript [ECMA-262] value can be converted to a key by following the steps to convert a value to a key .
An array key is a key with type array . The subkeys of an array key are the items of the array key 's value .
To compare two keys a and b , run these steps:
- 
Let ta be the type of a . 
- 
Let tb be the type of b . 
- 
If ta does not equal tb , then run these steps: - 
If ta is array , then return 1. 
- 
If tb is array , then return -1. 
- 
If ta is binary , then return 1. 
- 
If tb is binary , then return -1. 
- 
If ta is string , then return 1. 
- 
If tb is string , then return -1. 
- 
If ta is date , then return 1. 
- 
Assert : tb is date . 
- 
Return -1. 
 
- 
- 
Let va be the value of a . 
- 
Let vb be the value of b . 
- 
Switch on ta : - 
number
- date
- 
- 
If va is greater than vb , then return 1. 
- 
If va is less than vb , then return -1. 
- 
Return 0. 
 
- 
- string
- 
- 
If va is code unit less than vb , then return -1. 
- 
If vb is code unit less than va , then return 1. 
- 
Return 0. 
 
- 
- binary
- 
- 
If va is byte less than vb , then return -1. 
- 
If vb is byte less than va , then return 1. 
- 
Return 0. 
 
- 
- array
- 
- 
Let i be 0. 
- 
While i is less than length , then: - 
Let c be the result of recursively comparing two keys with va [ i ] and vb [ i ]. 
- 
If c is not 0, return c . 
- 
Increase i by 1. 
 
- 
- 
Return 0. 
 
 
- 
number
The key a is greater than the key b if the result of comparing two keys with a and b is 1.
The key a is less than the key b if the result of comparing two keys with a and b is -1.
The key a is equal to the key b if the result of comparing two keys with a and b is 0.
2.5. Key path
A key path is a string or list of strings that defines how to extract a key from a value . A valid key path is one of:
- 
An empty string. 
- 
An identifier , which is a string matching the IdentifierName production from the ECMAScript Language Specification [ECMA-262] . 
- 
A string consisting of two or more identifiers separated by periods (U+002E FULL STOP). 
- 
A non-empty list containing only strings conforming to the above requirements. 
Key path values can only be accessed from properties explicitly copied by StructuredSerializeForStorage , as well as the following type-specific properties:
| Type | Properties | 
|---|---|
| 
Blob
 | 
size
,
type
 | 
| 
File
 | 
name
,
lastModified
 | 
| Array | 
length
 | 
| String | 
length
 | 
2.6. Index
It is sometimes useful to retrieve records in an object store through other means than their key . An index allows looking up records in an object store using properties of the values in the object stores records .
An index is a specialized persistent key-value storage and has a referenced object store . The index has a list of records which hold the data stored in the index. The records in an index are automatically populated whenever records in the referenced object store are inserted, updated or deleted. There can be several indexes referencing the same object store , in which changes to the object store cause all such indexes to get updated.
The values in the index’s records are always values of keys in the index’s referenced object store. The keys are derived from the referenced object store’s values using a key path . If a given record with key X in the object store referenced by the index has the value A , and evaluating the index’s key path on A yields the result Y , then the index will contain a record with key Y and value X .
Records in an index are said to have a referenced value . This is the value of the record in the index’s referenced object store which has a key equal to the index’s record’s value. So in the example above, the record in the index whose key is Y and value is X has a referenced value of A .
The records in an index are always sorted according to the record 's key. However unlike object stores, a given index can contain multiple records with the same key. Such records are additionally sorted according to the index 's record 's value (meaning the key of the record in the referenced object store ).
An index has a name , which is a name . At any one time, the name is unique within index’s referenced object store .
An index has a unique flag . When true, the index enforces that no two records in the index has the same key. If a record in the index’s referenced object store is attempted to be inserted or modified such that evaluating the index’s key path on the records new value yields a result which already exists in the index, then the attempted modification to the object store fails.
An index has a multiEntry flag . This flag affects how the index behaves when the result of evaluating the index’s key path yields an array key . If its multiEntry flag is false, then a single record whose key is an array key is added to the index. If its multiEntry flag is true, then one record is added to the index for each of the subkeys .
2.6.1. Index handle
Script does not interact with indexes directly. Instead, within a transaction , script has indirect access via an index handle .
An index handle has an associated index and an associated object store handle . The transaction of an index handle is the transaction of its associated object store handle . Multiple handles may be associated with the same index in different transactions , but there must be only one index handle associated with a particular index within a transaction .
An index handle has a name , which is initialized to the name of the associated index when the index handle is created. The name will remain constant except when an upgrade transaction is running.
2.7. Transactions
A transaction is used to interact with the data in a database . Whenever data is read or written to the database it is done by using a transaction .
Transactions offer some protection from application and system failures. A transaction may be used to store multiple data records or to conditionally modify certain data records. A transaction represents an atomic and durable set of data access and data mutation operations.
All transactions are created through a connection , which is the transaction’s connection .
A transaction has a scope which is a set of object stores that the transaction may interact with.
Note: A transaction 's scope remains fixed unless the transaction is an upgrade transaction .
Two transactions have overlapping scope if any object store is in both transactions' scope .
A transaction has a mode that determines which types of interactions can be performed upon that transaction. The mode is set when the transaction is created and remains fixed for the life of the transaction. A transaction 's mode is one of the following:
- 
"readonly"
- 
The transaction is only allowed to read data. No modifications can be done by this type of transaction. This has the advantage that several read-only transactions can run at the same time even if their scopes are overlapping , i.e. if they are using the same object stores. This type of transaction can be created any time once a database has been opened. 
- 
"readwrite"
- 
The transaction is allowed to read, modify and delete data from existing object stores. However object stores and indexes can’t be added or removed. Multiple "readwrite"transactions can’t run at the same time if their scopes are overlapping since that would mean that they can modify each other’s data in the middle of the transaction. This type of transaction can be created any time once a database has been opened.
- 
"versionchange"
- 
The transaction is allowed to read, modify and delete data from existing object stores, and can also create and remove object stores and indexes. It is the only type of transaction that can do so. This type of transaction can’t be manually created, but instead is created automatically when an upgradeneededevent is fired.
A transaction has a durability hint . This is a hint to the user agent of whether to prioritize performance or durability when committing the transaction. The durability hint is one of the following:
- 
"strict"
- 
The user agent may consider that the transaction has successfully committed only after verifying that all outstanding changes have been successfully written to a persistent storage medium. 
- 
"relaxed"
- 
The user agent may consider that the transaction has successfully committed as soon as all outstanding changes have been written to the operating system, without subsequent verification. 
- 
"default"
- 
The user agent should use its default durability behavior for the storage bucket . This is the default for transactions if not otherwise specified. 
A transaction optionally has a cleanup event loop which is an event loop .
A transaction has a request list of pending requests which have been made against the transaction.
A transaction has a error which is set if the transaction is aborted .
A transaction 's get the parent algorithm returns the transaction’s connection .
A
read-only
transaction
is
a
transaction
with
mode
"readonly"
.
A
read/write
transaction
is
a
transaction
with
mode
"readwrite"
.
2.7.1. Transaction lifecycle
A transaction has a state , which is one of the following:
- active
- 
A transaction is in this state when it is first created , and during dispatch of an event from a request associated with the transaction. New requests can be made against the transaction when it is in this state. 
- inactive
- 
A transaction is in this state after control returns to the event loop after its creation, and when events are not being dispatched. No requests can be made against the transaction when it is in this state. 
- committing
- 
Once all requests associated with a transaction have completed, the transaction will enter this state as it attempts to commit . No requests can be made against the transaction when it is in this state. 
- finished
- 
Once a transaction has committed or aborted, it enters this state. No requests can be made against the transaction when it is in this state. 
Transactions are expected to be short lived. This is encouraged by the automatic committing functionality described below.
The lifetime of a transaction is as follows:
- 
A transaction is created with a scope and a mode . When a transaction is created its state is initially active . 
- 
When an implementation is able to enforce the constraints for the transaction’s scope and mode , defined below , the implementation must queue a task to start the transaction asynchronously. Once the transaction has been started the implementation can begin executing the requests placed against the transaction. Requests must be executed in the order in which they were made against the transaction. Likewise, their results must be returned in the order the requests were placed against a specific transaction. There is no guarantee about the order that results from requests in different transactions are returned. 
- 
When each request associated with a transaction is processed , a successorerrorevent will be fired. While the event is being dispatched , the transaction state is set to active , allowing additional requests to be made against the transaction. Once the event dispatch is complete, the transaction’s state is set to inactive again.
- 
A transaction can be aborted at any time before it is finished , even if the transaction isn’t currently active or hasn’t yet started . An explicit call to abort()will initiate an abort . An abort will also be initiated following a failed request that is not handled by script.When a transaction is aborted the implementation must undo (roll back) any changes that were made to the database during that transaction. This includes both changes to the contents of object stores as well as additions and removals of object stores and indexes . 
- 
The implementation must attempt to commit a transaction when all requests placed against the transaction have completed and their returned results handled, no new requests have been placed against the transaction, and the transaction has not been aborted An explicit call to commit()will initiate a commit without waiting for request results to be handled by script.When committing, the transaction state is set to committing . The implementation must atomically write any changes to the database made by requests placed against the transaction. That is, either all of the changes must be written, or if an error occurs, such as a disk write error, the implementation must not write any of the changes to the database, and the steps to abort a transaction will be followed. 
- 
When a transaction is committed or aborted , its state is set to finished . 
The implementation must allow requests to be placed against the transaction whenever it is active . This is the case even if the transaction has not yet been started . Until the transaction is started the implementation must not execute these requests; however, the implementation must keep track of the requests and their order.
To cleanup Indexed Database transactions , run the following steps. They will return true if any transactions were cleaned up, or false otherwise.
- 
If there are no transactions with cleanup event loop matching the current event loop , return false. 
- 
For each transaction transaction with cleanup event loop matching the current event loop : 
- 
Clear transaction ’s cleanup event loop . 
 
- 
Return true. 
An
event
with
type
complete
is
fired
at
a
transaction
that
has
successfully
committed
.
An
event
with
type
abort
is
fired
at
a
transaction
that
has
aborted
.
2.7.2. Transaction scheduling
The following constraints define when a transaction can be started :
- 
A read-only transactions tx can start when there are no read/write transactions which: - 
Were created before tx ; and 
- 
have overlapping scopes with tx ; and 
- 
are not finished . 
 
- 
- 
A read/write transaction tx can start when there are no transactions which: - 
Were created before tx ; and 
- 
have overlapping scopes with tx ; and 
- 
are not finished . 
 
- 
Implementations may impose additional constraints. For example, implementations are not required to run non- overlapping read/write transactions in parallel, or may impose limits on the number of running transactions.
2.7.3. Upgrade transactions
An
upgrade
transaction
is
a
transaction
with
mode
"versionchange"
.
An
upgrade
transaction
is
automatically
created
when
running
the
steps
to
run
an
upgrade
transaction
after
a
connection
is
opened
to
a
database
,
if
a
version
greater
than
the
current
version
is
specified.
This
transaction
will
be
active
inside
the
upgradeneeded
event
handler.
2.8. Requests
Each asynchronous operation on a database is done using a request . Every request represents one operation.
A request has a processed flag which is initially false. This flag is set to true when the operation associated with the request has been executed.
A request is said to be processed when its processed flag is true.
A request has a done flag which is initially false. This flag is set to true when the result of the operation associated with the request is available.
A request has a source object.
A request has a result and an error , neither of which are accessible until its done flag is true.
A request has a transaction which is initially null. This will be set when a request is placed against a transaction using the steps to asynchronously execute a request .
When
a
request
is
made,
a
new
request
is
returned
with
its
done
flag
set
to
false.
If
a
request
completes
successfully,
its
done
flag
is
set
to
true,
its
result
is
set
to
the
result
of
the
request,
and
an
event
with
type
success
is
fired
at
the
request
.
If
an
error
occurs
while
performing
the
operation,
the
request’s
done
flag
is
set
to
true,
the
request’s
error
is
set
to
the
error,
and
an
event
with
type
error
is
fired
at
the
request.
A request 's get the parent algorithm returns the request’s transaction .
2.8.1. Open requests
An
open
request
is
a
special
type
of
request
used
when
opening
a
connection
or
deleting
a
database
.
In
addition
to
success
and
error
events,
blocked
and
upgradeneeded
events
may
be
fired
at
an
open
request
to
indicate
progress.
The source of an open request is always null.
The
transaction
of
an
open
request
is
null
unless
an
upgradeneeded
event
has
been
fired.
An open request 's get the parent algorithm returns null.
Open requests are processed in a connection queue . The queue contains all open requests associated with an origin and a name . Requests added to the connection queue processed in order and each request must run to completion before the next request is processed. An open request may be blocked on other connections , requiring those connections to close before the request can complete and allow further requests to be processed.
2.9. Key range
Records can be retrieved from object stores and indexes using either keys or key ranges . A key range is a continuous interval over some data type used for keys.
A key range has an associated lower bound (null or a key ).
A key range has an associated upper bound (null or a key ).
A key range has an associated lower open flag . Unless otherwise stated it is false.
A key range has an associated upper open flag . Unless otherwise stated it is false.
A key range may have a lower bound equal to its upper bound . A key range must not have a lower bound greater than its upper bound .
A key range containing only key has both lower bound and upper bound equal to key .
A key is in a key range range if both of the following conditions are fulfilled:
- 
The range ’s lower bound is null, or it is less than key , or it is both equal to key and the range ’s lower open flag is false. 
- 
The range ’s upper bound is null, or it is greater than key , or it is both equal to key and the range ’s upper open flag is false. 
An unbounded key range is a key range that has both lower bound and upper bound equal to null. All keys are in an unbounded key range .
To convert a value to a key range with value and optional null disallowed flag , run these steps:
- 
If value is a key range , return value . 
- 
If value is undefined or is null, then throw a " DataError"DOMExceptionif null disallowed flag is true, or return an unbounded key range otherwise.
- 
Let key be the result of converting a value to a key with value . Rethrow any exceptions. 
- 
If key is invalid, throw a " DataError"DOMException.
- 
Return a key range containing only key . 
2.10. Cursor
A cursor is used to iterate over a range of records in an index or an object store in a specific direction.
A cursor has a transaction , the transaction that was active when the cursor was created.
A cursor has a range of records in either an index or an object store .
A cursor has a source that indicates which index or an object store is associated with the records over which the cursor is iterating.
A cursor has a direction that determines whether it moves in monotonically increasing or decreasing order of the record keys when iterated, and if it skips duplicated values when iterating indexes. The direction of a cursor also determines if the cursor initial position is at the start of its source or at its end. A cursor’s direction is one of the following:
- 
"next"
- 
This direction causes the cursor to be opened at the start of the source . When iterated, the cursor should yield all records, including duplicates, in monotonically increasing order of keys. 
- 
"nextunique"
- 
This direction causes the cursor to be opened at the start of the source . When iterated, the cursor should not yield records with the same key, but otherwise yield all records, in monotonically increasing order of keys. For every key with duplicate values, only the first record is yielded. When the source is an object store or an index with its unique flag set to true, this direction has exactly the same behavior as "next".
- 
"prev"
- 
This direction causes the cursor to be opened at the end of the source . When iterated, the cursor should yield all records, including duplicates, in monotonically decreasing order of keys. 
- 
"prevunique"
- 
This direction causes the cursor to be opened at the end of the source . When iterated, the cursor should not yield records with the same key, but otherwise yield all records, in monotonically decreasing order of keys. For every key with duplicate values, only the first record is yielded. When the source is an object store or an index with its unique flag set to true, this direction has exactly the same behavior as "prev".
A cursor has a position within its range. It is possible for the list of records which the cursor is iterating over to change before the full range of the cursor has been iterated. In order to handle this, cursors maintain their position not as an index, but rather as a key of the previously returned record. For a forward iterating cursor, the next time the cursor is asked to iterate to the next record it returns the record with the lowest key greater than the one previously returned. For a backwards iterating cursor, the situation is opposite and it returns the record with the highest key less than the one previously returned.
For cursors iterating indexes the situation is a little bit more complicated since multiple records can have the same key and are therefore also sorted by value . When iterating indexes the cursor also has an object store position , which indicates the value of the previously found record in the index. Both position and the object store position are used when finding the next appropriate record.
A cursor has a key and a value which represent the key and the value of the last iterated record .
A cursor has a got value flag . When this flag is false, the cursor is either in the process of loading the next value or it has reached the end of its range . When it is true, it indicates that the cursor is currently holding a value and that it is ready to iterate to the next one.
If the source of a cursor is an object store , the effective object store of the cursor is that object store and the effective key of the cursor is the cursor’s position . If the source of a cursor is an index , the effective object store of the cursor is that index’s referenced object store and the effective key is the cursor’s object store position .
A cursor has a request , which is the request used to open the cursor.
A cursor also has a key only flag , that indicates whether the cursor’s value is exposed via the API.
2.11. Key generators
When a object store is created it can be specified to use a key generator . A key generator is used to generate keys for records inserted into an object store if not otherwise specified.
A key generator has a current number . The current number is always a positive integer less than or equal to 2 53 (9007199254740992) + 1. The initial value of a key generator 's current number is 1, set when the associated object store is created. The current number is incremented as keys are generated, and may be updated to a specific value by using explicit keys.
Modifying a key generator’s current number is considered part of a database operation. This means that if the operation fails and the operation is reverted, the current number is reverted to the value it had before the operation started. This applies both to modifications that happen due to the current number getting increased by 1 when the key generator is used, and to modifications that happen due to a record being stored with a key value specified in the call to store the record .
Likewise, if a transaction is aborted, the current number of the key generator for each object store in the transaction’s scope is reverted to the value it had before the transaction was started.
The
current
number
for
a
key
generator
never
decreases,
other
than
as
a
result
of
database
operations
being
reverted.
Deleting
a
record
from
an
object
store
never
affects
the
object
store’s
key
generator.
Even
clearing
all
records
from
an
object
store,
for
example
using
the
clear()
method,
does
not
affect
the
current
number
of
the
object
store’s
key
generator.
When a record is stored and a key is not specified in the call to store the record, a key is generated.
To generate a key for an object store store , run these steps:
- 
Let generator be store ’s key generator . 
- 
Let key be generator ’s current number . 
- 
If key is greater than 2 53 (9007199254740992), then return failure. 
- 
Increase generator ’s current number by 1. 
- 
Return key . 
When a record is stored and a key is specified in the call to store the record, the associated key generator may be updated.
To possibly update the key generator for an object store store with key , run these steps:
- 
If the type of key is not number , abort these steps. 
- 
Let value be the value of key . 
- 
Let value be the minimum of value and 2 53 (9007199254740992). 
- 
Let value be the largest integer not greater than value . 
- 
Let generator be store ’s key generator . 
- 
If value is greater than or equal to generator ’s current number , then set generator ’s current number to value + 1. 
When
the
current
number
of
a
key
generator
reaches
above
the
value
2
53
(9007199254740992)
any
subsequent
attempts
to
use
the
key
generator
to
generate
a
new
key
will
result
in
a
"
ConstraintError
"
DOMException
.
It
is
still
possible
to
insert
records
into
the
object
store
by
specifying
an
explicit
key,
however
the
only
way
to
use
a
key
generator
again
for
such
records
is
to
delete
the
object
store
and
create
a
new
one.
A practical result of this is that the first key generated for an object store is always 1 (unless a higher numeric key is inserted first) and the key generated for an object store is always a positive integer higher than the highest numeric key in the store. The same key is never generated twice for the same object store unless a transaction is rolled back.
3. Exceptions
Each
of
the
exceptions
used
in
this
document
is
a
DOMException
with
a
specific
type.
The
exception
types
and
properties
such
as
legacy
code
value
are
defined
in
[WEBIDL]
.
The
table
below
lists
the
DOMException
s
used
in
this
document
along
with
a
description
of
the
exception
type’s
usage.
| Type | Description | 
|---|---|
| 
AbortError
 | A request was aborted. | 
| 
ConstraintError
 | A mutation operation in the transaction failed because a constraint was not satisfied. | 
| 
DataCloneError
 | The data being stored could not be cloned by the internal structured cloning algorithm. | 
| 
DataError
 | Data provided to an operation does not meet requirements. | 
| 
InvalidAccessError
 | An invalid operation was performed on an object. | 
| 
InvalidStateError
 | An operation was called on an object on which it is not allowed or at a time when it is not allowed, or if a request is made on a source object that has been deleted or removed. | 
| 
NotFoundError
 | The operation failed because the requested database object could not be found. | 
| 
QuotaExceededError
 | The operation failed because there was not enough remaining storage space, or the storage quota was reached and the user declined to give more space to the database. | 
| 
SyntaxError
 | The keyPath argument contains an invalid key path. | 
| 
ReadOnlyError
 | The mutating operation was attempted in a read-only transaction. | 
| 
TransactionInactiveError
 | A request was placed against a transaction which is currently not active, or which is finished. | 
| 
UnknownError
 | The operation failed for reasons unrelated to the database itself and not covered by any other errors. | 
| 
VersionError
 | An attempt was made to open a database using a lower version than the existing version. | 
4. API
The
API
methods
return
without
blocking
the
calling
thread.
All
asynchronous
operations
immediately
return
an
IDBRequest
instance.
This
object
does
not
initially
contain
any
information
about
the
result
of
the
operation.
Once
information
becomes
available,
an
event
is
fired
on
the
request
and
the
information
becomes
available
through
the
properties
of
the
IDBRequest
instance.
The task source for these tasks is the database access task source .
4.1.
The
IDBRequest
interface
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
IDBRequest
interface
provides
the
means
to
access
results
of
asynchronous
requests
to
databases
and
database
objects
using
event
handler
IDL
attributes
[HTML]
.
Every
method
for
making
asynchronous
requests
returns
an
IDBRequest
object
that
communicates
back
to
the
requesting
application
through
events.
This
design
means
that
any
number
of
requests
can
be
active
on
any
database
at
a
time.
[Exposed =(Window ,Worker )]interface :IDBRequest EventTarget {readonly attribute any result ;readonly attribute DOMException ?error ;readonly attribute (IDBObjectStore or IDBIndex or IDBCursor )?source ;readonly attribute IDBTransaction ?transaction ;readonly attribute IDBRequestReadyState readyState ; // Event handlers:attribute EventHandler onsuccess ;attribute EventHandler onerror ; };enum {IDBRequestReadyState ,"pending" };"done" 
- 
request
.
result
- 
When a request is completed, returns the result , or undefinedif the request failed. Throws a "InvalidStateError"DOMExceptionif the request is still pending.
- 
request
.
error
- 
When a request is completed, returns the error (a DOMException), or null if the request succeeded. Throws a "InvalidStateError"DOMExceptionif the request is still pending.
- 
request
.
source
- 
Returns the IDBObjectStore,IDBIndex, orIDBCursorthe request was made against, or null if it was an open request .
- 
request
.
transaction
- 
Returns the IDBTransactionthe request was made within. If this as an open request , then it returns an upgrade transaction while it is running, or null otherwise.
- 
request
.
readyState
- 
Returns "pending"until a request is complete, then returns"done".
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
result
getter
steps
are:
- 
If this 's done flag is false, then throw an " InvalidStateError"DOMException.
- 
Otherwise, return this 's result , or undefined if the request resulted in an error. 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
error
getter
steps
are:
- 
If this 's done flag is false, then throw an " InvalidStateError"DOMException.
- 
Otherwise, return this 's error , or null if no error occurred. 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
source
getter
steps
are
to
return
this
's
source
,
or
null
if
no
source
is
set.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
transaction
getter
steps
are
to
return
this
's
transaction
.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
readyState
getter
steps
are
to
return
"pending"
if
this
's
done
flag
is
false,
and
"done"
otherwise.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
onsuccess
attribute
is
an
event
handler
IDL
attribute
whose
event
handler
event
type
is
success
.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
onerror
attribute
is
an
event
handler
IDL
attribute
whose
event
handler
event
type
is
error
event.
Methods
on
IDBDatabase
that
return
a
open
request
use
an
extended
interface
to
allow
listening
to
the
blocked
and
upgradeneeded
events.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
[Exposed =(Window ,Worker )]interface :IDBOpenDBRequest IDBRequest { // Event handlers:attribute EventHandler onblocked ;attribute EventHandler onupgradeneeded ; };
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
onblocked
attribute
is
an
event
handler
IDL
attribute
whose
event
handler
event
type
is
blocked
.
IDBOpenDBRequest/onupgradeneeded
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
onupgradeneeded
attribute
is
an
event
handler
IDL
attribute
whose
event
handler
event
type
is
upgradeneeded
.
4.2. Event interfaces
This specification fires events with the following custom interfaces:
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari Yes Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile Yes
[Exposed =(Window ,Worker )]interface :IDBVersionChangeEvent Event {(constructor DOMString ,type optional IDBVersionChangeEventInit = {});eventInitDict readonly attribute unsigned long long oldVersion ;readonly attribute unsigned long long ?newVersion ; };dictionary :IDBVersionChangeEventInit EventInit {unsigned long long = 0;oldVersion unsigned long long ?=newVersion null ; };
IDBVersionChangeEvent/oldVersion
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
oldVersion
getter
steps
are
to
return
the
value
it
was
initialized
to.
It
represents
the
previous
version
of
the
database.
IDBVersionChangeEvent/newVersion
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
newVersion
getter
steps
are
to
return
the
value
it
was
initialized
to.
It
represents
the
new
version
of
the
database,
or
null
if
the
database
is
being
deleted.
See
the
steps
to
run
an
upgrade
transaction
.
Events are constructed as defined in DOM §2.5 Constructing events .
To fire a version change event named e at target given oldVersion and newVersion , run these steps:
- 
Let event be the result of creating an event using IDBVersionChangeEvent.
- 
Set event ’s typeattribute to e .
- 
Set event ’s bubblesandcancelableattributes to false.
- 
Set event ’s oldVersionattribute to oldVersion .
- 
Set event ’s newVersionattribute to newVersion .
- 
Let legacyOutputDidListenersThrowFlag be false. 
- 
Dispatch event at target with legacyOutputDidListenersThrowFlag . 
- 
Return legacyOutputDidListenersThrowFlag . 
4.3.
The
IDBFactory
interface
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
Database
objects
are
accessed
through
methods
on
the
IDBFactory
interface.
A
single
object
implementing
this
interface
is
present
in
the
global
scope
of
environments
that
support
Indexed
DB
operations.
partial interface mixin WindowOrWorkerGlobalScope { [SameObject ]readonly attribute IDBFactory indexedDB ; };
WindowOrWorkerGlobalScope/indexedDB
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 2.0+ Opera Mobile 14+
The
indexedDB
attribute
provides
applications
a
mechanism
for
accessing
capabilities
of
indexed
databases.
[Exposed =(Window ,Worker )]interface { [IDBFactory NewObject ]IDBOpenDBRequest open (DOMString ,name optional [EnforceRange ]unsigned long long ); [version NewObject ]IDBOpenDBRequest deleteDatabase (DOMString );name Promise <sequence <IDBDatabaseInfo >>databases ();short cmp (any ,first any ); };second dictionary {IDBDatabaseInfo DOMString ;name unsigned long long ; };version 
- 
request
=
indexedDB
.
open( name )
- 
Attempts to open a connection to the named database with the current version, or 1 if it does not already exist. If the request is successful request ’s resultwill be the connection .
- 
request
=
indexedDB
.
open( name , version )
- 
Attempts to open a connection to the named database with the specified version . If the database already exists with a lower version and there are open connections that don’t close in response to a versionchangeevent, the request will be blocked until they all close, then an upgrade will occur. If the database already exists with a higher version the request will fail. If the request is successful request ’sresultwill be the connection .
- 
request
=
indexedDB
.
deleteDatabase( name )
- 
Attempts to delete the named database . If the database already exists and there are open connections that don’t close in response to a versionchangeevent, the request will be blocked until they all close. If the request is successful request ’sresultwill be null.
- 
result
=
await
indexedDB
.
databases()
- 
Returns a promise which resolves to a list of objects giving a snapshot of the names and versions of databases within the origin. This API is intended for web applications to introspect the use of databases, for example to clean up from earlier versions of a site’s code. Note that the result is a snapshot; there are no guarantees about the sequencing of the collection of the data or the delivery of the response with respect to requests to create, upgrade, or delete databases by this context or others. 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
open(
name
,
version
)
method
steps
are:
- 
Let environment be this 's relevant settings object . 
- 
Let origin be environment ’s origin . 
- 
If origin is an opaque origin , throw a " SecurityError"DOMExceptionand abort these steps.
- 
Let request be a new open request . 
- 
Run these steps in parallel : - 
Let result be the result of opening a database , with origin , name , version if given and undefined otherwise, and request . 
- 
Queue a task to run these steps: - 
If result is an error, then: - 
Set request ’s result to undefined. 
- 
Set request ’s error to result . 
- 
Set request ’s done flag to true. 
- 
Fire an event named errorat request with itsbubblesandcancelableattributes initialized to true.
 
- 
- 
Otherwise: - 
Set request ’s result to result . 
- 
Set request ’s done flag to true. 
- 
Fire an event named successat request .
 Why aren’t the steps to fire a success event or fire an error event used?There is no transaction associated with the request (at this point), so those steps — which activate an associated transaction before dispatch and deactivate the transaction after dispatch — do not apply.
- 
 
- 
 
- 
- 
Return a new IDBOpenDBRequestobject for request .
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
deleteDatabase(
name
)
method
steps
are:
- 
Let environment be this 's relevant settings object . 
- 
Let origin be environment ’s origin . 
- 
If origin is an opaque origin , throw a " SecurityError"DOMExceptionand abort these steps.
- 
Let request be a new open request . 
- 
Run these steps in parallel : - 
Let result be the result of deleting a database , with origin , name , and request . 
- 
Set request ’s processed flag to true. 
- 
Queue a task to run these steps: - 
If result is an error, set request ’s error to result , set request ’s done flag to true, and fire an event named errorat request with itsbubblesandcancelableattributes initialized to true.
- 
Otherwise, set request ’s result to undefined, set request ’s done flag to true, and fire a version change event named successat request with result and null.Why aren’t the steps to fire a success event or fire an error event used?There is no transaction associated with the request, so those steps — which activate an associated transaction before dispatch and deactivate the transaction after dispatch — do not apply.Also, the successevent here is aIDBVersionChangeEventwhich includes theoldVersionandnewVersiondetails.
 
- 
 
- 
- 
Return a new IDBOpenDBRequestobject for request .
Opera 58+ Edge 79+
Edge (Legacy) None IE None
Firefox for Android None iOS Safari 14+ Chrome for Android 71+ Android WebView 71+ Samsung Internet 10.0+ Opera Mobile Yes
The
databases()
method
steps
are:
- 
Let environment be this 's relevant settings object . 
- 
Let origin be environment ’s origin . 
- 
If origin is an opaque origin , then return a promise rejected with a " SecurityError"DOMException.
- 
Let p be a new promise . 
- 
Run these steps in parallel : - 
Let databases be the set of databases in origin . If this cannot be determined for any reason, then reject p with an appropriate error (e.g. an " UnknownError"DOMException) and terminate these steps.
- 
Let result be a new list . 
- 
For each db of databases : 
- 
Resolve p with result . 
 
- 
- 
Return p . 
- 
result
=
indexedDB
.
cmp( key1 , key2 )
- 
Compares two values as keys . Returns -1 if key1 precedes key2 , 1 if key2 precedes key1 , and 0 if the keys are equal. Throws a " DataError"DOMExceptionif either input is not a valid key .
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
cmp(
first
,
second
)
method
steps
are:
- 
Let a be the result of converting a value to a key with first . Rethrow any exceptions. 
- 
If a is invalid, throw a " DataError"DOMException.
- 
Let b be the result of converting a value to a key with second . Rethrow any exceptions. 
- 
If b is invalid, throw a " DataError"DOMException.
- 
Return the results of comparing two keys with a and b . 
4.4.
The
IDBDatabase
interface
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
IDBDatabase
interface
represents
a
connection
to
a
database
.
An
IDBDatabase
object
must
not
be
garbage
collected
if
its
associated
connection
's
close
pending
flag
is
false
and
it
has
one
or
more
event
listeners
registers
whose
type
is
one
of
abort
,
error
,
or
versionchange
.
If
an
IDBDatabase
object
is
garbage
collected,
the
associated
connection
must
be
closed
.
[Exposed =(Window ,Worker )]interface :IDBDatabase EventTarget {readonly attribute DOMString name ;readonly attribute unsigned long long version ;readonly attribute DOMStringList objectStoreNames ; [NewObject ]IDBTransaction transaction ((DOMString or sequence <DOMString >),storeNames optional IDBTransactionMode = "readonly",mode optional IDBTransactionOptions = {});options undefined close (); [NewObject ]IDBObjectStore createObjectStore (DOMString ,name optional IDBObjectStoreParameters = {});options undefined deleteObjectStore (DOMString ); // Event handlers:name attribute EventHandler onabort ;attribute EventHandler onclose ;attribute EventHandler onerror ;attribute EventHandler onversionchange ; };enum {IDBTransactionDurability ,"default" ,"strict" };"relaxed" dictionary {IDBTransactionOptions IDBTransactionDurability = "default"; };durability dictionary { (IDBObjectStoreParameters DOMString or sequence <DOMString >)?=keyPath null ;boolean =autoIncrement false ; };
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
name
getter
steps
are
to
return
this
's
associated
database
's
name
.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
version
getter
steps
are
to
return
this
's
version
.
Is this the same as the database 's version ?
As long as the connection is open, this is the same as the connected database 's version . But once the connection has closed , this attribute will not reflect changes made with a later upgrade transaction .- 
connection
.
objectStoreNames
- 
Returns a list of the names of object stores in the database. 
- 
store
=
connection
.
createObjectStore( name [, options ])
- 
Creates a new object store with the given name and options and returns a new IDBObjectStore.Throws a " InvalidStateError"DOMExceptionif not called within an upgrade transaction .
- 
connection
.
deleteObjectStore( name )
- 
Deletes the object store with the given name . Throws a " InvalidStateError"DOMExceptionif not called within an upgrade transaction .
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
objectStoreNames
getter
steps
are:
- 
Let names be a list of the names of the object stores in this 's object store set . 
- 
Return the result (a DOMStringList) of creating a sorted name list with names .
Is this the same as the database 's object store names ?
As long as the connection is open, this is the same as the connected database 's object store names . But once the connection has closed , this attribute will not reflect changes made with a later upgrade transaction .In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
createObjectStore(
name
,
options
)
method
steps
are:
- 
Let transaction be database ’s upgrade transaction if it is not null, or throw an " InvalidStateError"DOMExceptionotherwise.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
Let keyPath be options ’s keyPathmember if it is not undefined or null, or null otherwise.
- 
If keyPath is not null and is not a valid key path , throw a " SyntaxError"DOMException.
- 
If an object store named name already exists in database throw a " ConstraintError"DOMException.
- 
Let autoIncrement be options ’s autoIncrementmember.
- 
If autoIncrement is true and keyPath is an empty string or any sequence (empty or otherwise), throw an " InvalidAccessError"DOMException.
- 
Let store be a new object store in database . Set the created object store 's name to name . If autoIncrement is true, then the created object store uses a key generator . If keyPath is not null, set the created object store 's key path to keyPath . 
- 
Return a new object store handle associated with store and transaction . 
This method creates and returns a new object store with the given name in the connected database . Note that this method must only be called from within an upgrade transaction .
This
method
synchronously
modifies
the
objectStoreNames
property
on
the
IDBDatabase
instance
on
which
it
was
called.
In
some
implementations
it
is
possible
for
the
implementation
to
run
into
problems
after
queuing
a
task
to
create
the
object
store
after
the
createObjectStore()
method
has
returned.
For
example
in
implementations
where
metadata
about
the
newly
created
object
store
is
inserted
into
the
database
asynchronously,
or
where
the
implementation
might
need
to
ask
the
user
for
permission
for
quota
reasons.
Such
implementations
must
still
create
and
return
an
IDBObjectStore
object,
and
once
the
implementation
determines
that
creating
the
object
store
has
failed,
it
must
abort
the
transaction
using
the
steps
to
abort
a
transaction
using
the
appropriate
error.
For
example
if
creating
the
object
store
failed
due
to
quota
reasons,
a
"
QuotaExceededError
"
DOMException
must
be
used
as
error.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
deleteObjectStore(
name
)
method
steps
are:
- 
Let transaction be database ’s upgrade transaction if it is not null, or throw an " InvalidStateError"DOMExceptionotherwise.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
Let store be the object store named name in database , or throw a " NotFoundError"DOMExceptionif none.
- 
Remove store from this 's object store set . 
- 
If there is an object store handle associated with store and transaction , remove all entries from its index set . 
- 
Destroy store . 
This method destroys the object store with the given name in the connected database . Note that this method must only be called from within an upgrade transaction .
This
method
synchronously
modifies
the
objectStoreNames
property
on
the
IDBDatabase
instance
on
which
it
was
called.
- 
transaction
=
connection
.
transaction( scope [, mode [, options ] ])
- 
Returns a new transaction with the given scope (which can be a single object store name or an array of names ), mode ( "readonly"or"readwrite"), and additional options includingdurability("default","strict"or"relaxed").The default mode is "readonly"and the defaultdurabilityis"default".
- 
connection
.
close()
- 
Closes the connection once all running transactions have finished. 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
transaction(
storeNames
,
mode
,
options
)
method
steps
are:
- 
If a running upgrade transaction is associated with the connection , throw an " InvalidStateError"DOMException.
- 
If this 's close pending flag is true, then throw an " InvalidStateError"DOMException.
- 
Let scope be the set of unique strings in storeNames if it is a sequence, or a set containing one string equal to storeNames otherwise. 
- 
If any string in scope is not the name of an object store in the connected database , throw a " NotFoundError"DOMException.
- 
If scope is empty, throw an " InvalidAccessError"DOMException.
- 
If mode is not "readonly"or"readwrite", throw a TypeError .
- 
Let transaction be a newly created transaction with this connection , mode , options ’ durabilitymember, and the set of object stores named in scope .
- 
Set transaction ’s cleanup event loop to the current event loop . 
- 
Return an IDBTransactionobject representing transaction .
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
close()
method
steps
are:
- 
Run close a database connection with this connection . 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
onabort
attribute
is
an
event
handler
IDL
attribute
whose
event
handler
event
type
is
abort
.
In all current engines.
Opera Yes Edge 79+
Edge (Legacy) 18 IE None
Firefox for Android 50+ iOS Safari 10.3+ Chrome for Android 31+ Android WebView 37+ Samsung Internet 2.0+ Opera Mobile Yes
The
onclose
attribute
is
an
event
handler
IDL
attribute
whose
event
handler
event
type
is
close
.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
onerror
attribute
is
an
event
handler
IDL
attribute
whose
event
handler
event
type
is
error
.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
onversionchange
attribute
is
an
event
handler
IDL
attribute
whose
event
handler
event
type
is
versionchange
.
4.5.
The
IDBObjectStore
interface
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
IDBObjectStore
interface
represents
an
object
store
handle
.
[Exposed =(Window ,Worker )]interface {IDBObjectStore attribute DOMString name ;readonly attribute any keyPath ;readonly attribute DOMStringList indexNames ; [SameObject ]readonly attribute IDBTransaction transaction ;readonly attribute boolean autoIncrement ; [NewObject ]IDBRequest put (any ,value optional any ); [key NewObject ]IDBRequest add (any ,value optional any ); [key NewObject ]IDBRequest delete (any ); [query NewObject ]IDBRequest clear (); [NewObject ]IDBRequest get (any ); [query NewObject ]IDBRequest getKey (any ); [query NewObject ]IDBRequest getAll (optional any ,query optional [EnforceRange ]unsigned long ); [count NewObject ]IDBRequest getAllKeys (optional any ,query optional [EnforceRange ]unsigned long ); [count NewObject ]IDBRequest count (optional any ); [query NewObject ]IDBRequest openCursor (optional any ,query optional IDBCursorDirection = "next"); [direction NewObject ]IDBRequest openKeyCursor (optional any ,query optional IDBCursorDirection = "next");direction IDBIndex index (DOMString ); [name NewObject ]IDBIndex createIndex (DOMString , (name DOMString or sequence <DOMString >),keyPath optional IDBIndexParameters = {});options undefined deleteIndex (DOMString ); };name dictionary {IDBIndexParameters boolean =unique false ;boolean =multiEntry false ; };
- 
store
.
name
- 
Returns the name of the store. 
- 
store
.
name= newName
- 
Updates the name of the store to newName . Throws " InvalidStateError"DOMExceptionif not called within an upgrade transaction .
- 
store
.
keyPath
- 
Returns the key path of the store, or null if none. 
- 
store
.
indexNames
- 
Returns a list of the names of indexes in the store. 
- 
store
.
transaction
- 
Returns the associated transaction . 
- 
store
.
autoIncrement
- 
Returns true if the store has a key generator , and false otherwise. 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
name
getter
steps
are
to
return
this
's
name
.
Is this the same as the object store 's name ?
As long as the transaction has not finished , this is the same as the associated object store 's name . But once the transaction has finished , this attribute will not reflect changes made with a later upgrade transaction .
The
name
setter
steps
are:
- 
Let name be the given value . 
- 
Let transaction be this 's transaction . 
- 
Let store be this 's object store . 
- 
If store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction is not an upgrade transaction , throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , throw a " TransactionInactiveError"DOMException.
- 
If store ’s name is equal to name , terminate these steps. 
- 
If an object store named name already exists in store ’s database , throw a " ConstraintError"DOMException.
- 
Set store ’s name to name . 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
keyPath
getter
steps
are
to
return
this
's
object
store
's
key
path
,
or
null
if
none.
The
key
path
is
converted
as
a
DOMString
(if
a
string)
or
a
sequence
<
(if
a
list
of
strings),
per
[WEBIDL]
.
DOMString
>
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
indexNames
getter
steps
are:
- 
Let names be a list of the names of the indexes in this 's index set . 
- 
Return the result (a DOMStringList) of creating a sorted name list with names .
Is this the same as object store 's list of index names ?
As long as the transaction has not finished , this is the same as the associated object store 's list of index names . But once the transaction has finished , this attribute will not reflect changes made with a later upgrade transaction .In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
transaction
getter
steps
are
to
return
this
's
transaction
.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
autoIncrement
getter
steps
are
to
return
true
if
this
's
object
store
has
a
key
generator
,
and
false
otherwise.
ReadOnlyError
"
DOMException
if
called
within
a
read-only
transaction
,
and
a
"
TransactionInactiveError
"
DOMException
if
called
when
the
transaction
is
not
active
.
- 
request
=
store
.
put( value [, key ])
- request = store .
add( value [, key ])
- request = store .
- 
Adds or updates a record in store with the given value and key . If the store uses in-line keys and key is specified a " DataError"DOMExceptionwill be thrown.If put()is used, any existing record with the key will be replaced. Ifadd()is used, and if a record with the key already exists the request will fail, with request ’serrorset to a "ConstraintError"DOMException.If successful, request ’s resultwill be the record 's key .
- 
request
=
store
.
delete( query )
- 
Deletes records in store with the given key or in the given key range in query . If successful, request ’s resultwill beundefined.
- 
request
=
store
.
clear()
- 
Deletes all records in store . If successful, request ’s resultwill beundefined.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
put(
value
,
key
)
method
steps
are
to
return
the
result
of
running
add
or
put
with
this
,
value
,
key
and
the
no-overwrite
flag
false.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
add(
value
,
key
)
method
steps
are
to
return
the
result
of
running
add
or
put
with
this
,
value
,
key
and
the
no-overwrite
flag
true.
To add or put with handle , value , key , and no-overwrite flag , run these steps:
- 
Let transaction be handle ’s transaction . 
- 
Let store be handle ’s object store . 
- 
If store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
If transaction is a read-only transaction , throw a " ReadOnlyError"DOMException.
- 
If store uses in-line keys and key was given, throw a " DataError"DOMException.
- 
If store uses out-of-line keys and has no key generator and key was not given, throw a " DataError"DOMException.
- 
If key was given, then: - 
Let r be the result of converting a value to a key with key . Rethrow any exceptions. 
- 
If r is invalid, throw a " DataError"DOMException.
- 
Let key be r . 
 
- 
- 
Let targetRealm be a user-agent defined Realm . 
- 
Let clone be a clone of value in targetRealm during transaction . Rethrow any exceptions. Why create a copy of the value?The value is serialized when stored. Treating it as a copy here allows other algorithms in this specification to treat it as an ECMAScript value, but implementations can optimize this if the difference in behavior is not observable.
- 
If store uses in-line keys , then: - 
Let kpk be the result of extracting a key from a value using a key path with clone and store ’s key path . Rethrow any exceptions. 
- 
If kpk is invalid, throw a " DataError"DOMException.
- 
If kpk is not failure, let key be kpk . 
- 
Otherwise ( kpk is failure): - 
If store does not have a key generator , throw a " DataError"DOMException.
- 
Otherwise, if check that a key could be injected into a value with clone and store ’s key path return false, throw a " DataError"DOMException.
 
- 
 
- 
- 
Let operation be an algorithm to run store a record into an object store with store , clone , key , and no-overwrite flag . 
- 
Return the result (an IDBRequest) of running asynchronously execute a request with handle and operation .
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
delete(
query
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
Let store be this 's object store . 
- 
If store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
If transaction is a read-only transaction , throw a " ReadOnlyError"DOMException.
- 
Let range be the result of converting a value to a key range with query and true. Rethrow any exceptions. 
- 
Let operation be an algorithm to run delete records from an object store with store and range . 
- 
Return the result (an IDBRequest) of running asynchronously execute a request with this and operation .
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
clear()
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
Let store be this 's object store . 
- 
If store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
If transaction is a read-only transaction , throw a " ReadOnlyError"DOMException.
- 
Let operation be an algorithm to run clear an object store with store . 
- 
Return the result (an IDBRequest) of running asynchronously execute a request with this and operation .
TransactionInactiveError
"
DOMException
if
called
when
the
transaction
is
not
active
.
- 
request
=
store
.
get( query )
- 
Retrieves the value of the first record matching the given key or key range in query . If successful, request ’s resultwill be the value , orundefinedif there was no matching record .
- 
request
=
store
.
getKey( query )
- 
Retrieves the key of the first record matching the given key or key range in query . If successful, request ’s resultwill be the key , orundefinedif there was no matching record .
- 
request
=
store
.
getAll( query [, count ])
- 
Retrieves the values of the records matching the given key or key range in query (up to count if given). If successful, request ’s resultwill be an Array of the values .
- 
request
=
store
.
getAllKeys( query [, count ])
- 
Retrieves the keys of records matching the given key or key range in query (up to count if given). If successful, request ’s resultwill be an Array of the keys .
- 
request
=
store
.
count( query )
- 
Retrieves the number of records matching the given key or key range in query . If successful, request ’s resultwill be the count.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
get(
query
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
Let store be this 's object store . 
- 
If store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
Let range be the result of converting a value to a key range with query and true. Rethrow any exceptions. 
- 
Let operation be an algorithm to run retrieve a value from an object store with the current Realm , store , and range . 
- 
Return the result (an IDBRequest) of running asynchronously execute a request with this and operation .
In all current engines.
Opera 45+ Edge 79+
Edge (Legacy) None IE None
Firefox for Android 58+ iOS Safari 10.3+ Chrome for Android 48+ Android WebView 48+ Samsung Internet 5.0+ Opera Mobile 43+
The
getKey(
query
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
Let store be this 's object store . 
- 
If store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
Let range be the result of converting a value to a key range with query and true. Rethrow any exceptions. 
- 
Let operation be an algorithm to run retrieve a key from an object store with store and range . 
- 
Return the result (an IDBRequest) of running asynchronously execute a request with this and operation .
In all current engines.
Opera 35+ Edge 79+
Edge (Legacy) None IE None
Firefox for Android 48+ iOS Safari 10.3+ Chrome for Android 48+ Android WebView 48+ Samsung Internet 5.0+ Opera Mobile 35+
The
getAll(
query
,
count
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
Let store be this 's object store . 
- 
If store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
Let range be the result of converting a value to a key range with query . Rethrow any exceptions. 
- 
Let operation be an algorithm to run retrieve multiple values from an object store with the current Realm , store , range , and count if given. 
- 
Return the result (an IDBRequest) of running asynchronously execute a request with this and operation .
In all current engines.
Opera 35+ Edge 79+
Edge (Legacy) None IE None
Firefox for Android 48+ iOS Safari 10.3+ Chrome for Android 48+ Android WebView 48+ Samsung Internet 5.0+ Opera Mobile 35+
The
getAllKeys(
query
,
count
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
Let store be this 's object store . 
- 
If store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
Let range be the result of converting a value to a key range with query . Rethrow any exceptions. 
- 
Let operation be an algorithm to run retrieve multiple keys from an object store with store , range , and count if given. 
- 
Return the result (an IDBRequest) of running asynchronously execute a request with this and operation .
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
count(
query
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
Let store be this 's object store . 
- 
If store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
Let range be the result of converting a value to a key range with query . Rethrow any exceptions. 
- 
Let operation be an algorithm to run count the records in a range with store and range . 
- 
Return the result (an IDBRequest) of running asynchronously execute a request with this and operation .
TransactionInactiveError
"
DOMException
if
called
when
the
transaction
is
not
active
.
- 
request
=
store
.
openCursor([ query [, direction = "next"]])
- 
Opens a cursor over the records matching query , ordered by direction . If query is null, all records in store are matched. If successful, request ’s resultwill be anIDBCursorWithValuepointing at the first matching record , or null if there were no matching records .
- 
request
=
store
.
openKeyCursor([ query [, direction = "next"]])
- 
Opens a cursor with key only flag set to true over the records matching query , ordered by direction . If query is null, all records in store are matched. If successful, request ’s resultwill be anIDBCursorpointing at the first matching record , or null if there were no matching records .
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
openCursor(
query
,
direction
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
Let store be this 's object store . 
- 
If store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
Let range be the result of converting a value to a key range with query . Rethrow any exceptions. 
- 
Let cursor be a new cursor with its transaction set to transaction , undefined position , direction set to direction , got value flag set to false, undefined key and value , source set to store , range set to range , and key only flag set to false. 
- 
Let operation be an algorithm to run iterate a cursor with the current Realm cursor . 
- 
Let request be the result of running asynchronously execute a request with this and operation . 
- 
Set cursor ’s request to request . 
- 
Return request . 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
openKeyCursor(
query
,
direction
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
Let store be this 's object store . 
- 
If store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
Let range be the result of converting a value to a key range with query . Rethrow any exceptions. 
- 
Let cursor be a new cursor with its transaction set to transaction , undefined position , direction set to direction , got value flag set to false, undefined key and value , source set to store , range set to range , and key only flag set to true. 
- 
Let operation be an algorithm to run iterate a cursor with the current Realm and cursor . 
- 
Let request be the result of running asynchronously execute a request with this and operation . 
- 
Set cursor ’s request to request . 
- 
Return request . 
- index = store . index( name )
- 
index
=
store
.
createIndex( name , keyPath [, options ])
- 
Creates a new index in store with the given name , keyPath and options and returns a new IDBIndex. If the keyPath and options define constraints that cannot be satisfied with the data already in store the upgrade transaction will abort with a "ConstraintError"DOMException.Throws an " InvalidStateError"DOMExceptionif not called within an upgrade transaction .
- 
store
.
deleteIndex( name )
- 
Deletes the index in store with the given name . Throws an " InvalidStateError"DOMExceptionif not called within an upgrade transaction .
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
createIndex(
name
,
keyPath
,
options
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
Let store be this 's object store . 
- 
If transaction is not an upgrade transaction , throw an " InvalidStateError"DOMException.
- 
If store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
If an index named name already exists in store , throw a " ConstraintError"DOMException.
- 
If keyPath is not a valid key path , throw a " SyntaxError"DOMException.
- 
Let unique be options ’s uniquemember.
- 
Let multiEntry be options ’s multiEntrymember.
- 
If keyPath is a sequence and multiEntry is true, throw an " InvalidAccessError"DOMException.
- 
Let index be a new index in store . Set index ’s name to name , key path to keyPath , unique flag to unique , and multiEntry flag to multiEntry . 
- 
Return a new index handle associated with index and this . 
This method creates and returns a new index with the given name in the object store . Note that this method must only be called from within an upgrade transaction .
The
index
that
is
requested
to
be
created
can
contain
constraints
on
the
data
allowed
in
the
index’s
referenced
object
store,
such
as
requiring
uniqueness
of
the
values
referenced
by
the
index’s
key
path
.
If
the
referenced
object
store
already
contains
data
which
violates
these
constraints,
this
must
not
cause
the
implementation
of
createIndex()
to
throw
an
exception
or
affect
what
it
returns.
The
implementation
must
still
create
and
return
an
IDBIndex
object,
and
the
implementation
must
queue
a
task
to
abort
the
upgrade
transaction
which
was
used
for
the
createIndex()
call.
This
method
synchronously
modifies
the
indexNames
property
on
the
IDBObjectStore
instance
on
which
it
was
called.
Although
this
method
does
not
return
an
IDBRequest
object,
the
index
creation
itself
is
processed
as
an
asynchronous
request
within
the
upgrade
transaction
.
In
some
implementations
it
is
possible
for
the
implementation
to
asynchronously
run
into
problems
creating
the
index
after
the
createIndex
method
has
returned.
For
example
in
implementations
where
metadata
about
the
newly
created
index
is
queued
up
to
be
inserted
into
the
database
asynchronously,
or
where
the
implementation
might
need
to
ask
the
user
for
permission
for
quota
reasons.
Such
implementations
must
still
create
and
return
an
IDBIndex
object,
and
once
the
implementation
determines
that
creating
the
index
has
failed,
it
must
run
the
steps
to
abort
a
transaction
using
an
appropriate
error.
For
example
if
creating
the
index
failed
due
to
quota
reasons,
a
"
QuotaExceededError
"
DOMException
must
be
used
as
error
and
if
the
index
can’t
be
created
due
to
unique
flag
constraints,
a
"
ConstraintError
"
DOMException
must
be
used
as
error.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
index(
name
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
Let store be this 's object store . 
- 
If store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is finished , then throw an " InvalidStateError"DOMException.
- 
Let index be the index named name in this 's index set if one exists, or throw a " NotFoundError"DOMExceptionotherwise.
- 
Return an index handle associated with index and this . 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
deleteIndex(
name
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
Let store be this 's object store . 
- 
If transaction is not an upgrade transaction , throw an " InvalidStateError"DOMException.
- 
If store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
Let index be the index named name in store if one exists, or throw a " NotFoundError"DOMExceptionotherwise.
- 
Destroy index . 
This method destroys the index with the given name in the object store . Note that this method must only be called from within an upgrade transaction .
This
method
synchronously
modifies
the
indexNames
property
on
the
IDBObjectStore
instance
on
which
it
was
called.
Although
this
method
does
not
return
an
IDBRequest
object,
the
index
destruction
itself
is
processed
as
an
asynchronous
request
within
the
upgrade
transaction
.
4.6.
The
IDBIndex
interface
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
IDBIndex
interface
represents
an
index
handle
.
[Exposed =(Window ,Worker )]interface {IDBIndex attribute DOMString name ; [SameObject ]readonly attribute IDBObjectStore objectStore ;readonly attribute any keyPath ;readonly attribute boolean multiEntry ;readonly attribute boolean unique ; [NewObject ]IDBRequest get (any ); [query NewObject ]IDBRequest getKey (any ); [query NewObject ]IDBRequest getAll (optional any ,query optional [EnforceRange ]unsigned long ); [count NewObject ]IDBRequest getAllKeys (optional any ,query optional [EnforceRange ]unsigned long ); [count NewObject ]IDBRequest count (optional any ); [query NewObject ]IDBRequest openCursor (optional any ,query optional IDBCursorDirection = "next"); [direction NewObject ]IDBRequest openKeyCursor (optional any ,query optional IDBCursorDirection = "next"); };direction 
- 
index
.
name
- 
Returns the name of the index. 
- 
index
.
name= newName
- 
Updates the name of the store to newName . Throws an " InvalidStateError"DOMExceptionif not called within an upgrade transaction .
- 
index
.
objectStore
- 
Returns the IDBObjectStorethe index belongs to.
- index . keyPath
- 
Returns the key path of the index. 
- index . multiEntry
- 
Returns true if the index’s multiEntry flag is true. 
- index . unique
- 
Returns true if the index’s unique flag is true. 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
name
getter
steps
are
to
return
this
's
name
.
Is this the same as the index 's name ?
As long as the transaction has not finished , this is the same as the associated index 's name . But once the transaction has finished , this attribute will not reflect changes made with a later upgrade transaction .
The
name
setter
steps
are:
- 
Let name be the given value . 
- 
Let transaction be this 's transaction . 
- 
If transaction is not an upgrade transaction , throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
If index or index ’s object store has been deleted, throw an " InvalidStateError"DOMException.
- 
If index ’s name is equal to name , terminate these steps. 
- 
If an index named name already exists in index ’s object store , throw a " ConstraintError"DOMException.
- 
Set index ’s name to name . 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
objectStore
getter
steps
are
to
return
this
's
object
store
handle
.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
keyPath
getter
steps
are
to
return
this
's
index
's
key
path
.
The
key
path
is
converted
as
a
DOMString
(if
a
string)
or
a
sequence
<
(if
a
list
of
strings),
per
[WEBIDL]
.
DOMString
>
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
multiEntry
getter
steps
are
to
return
this
's
index
's
multiEntry
flag
.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
unique
getter
steps
are
to
return
this
's
index
's
unique
flag
.
TransactionInactiveError
"
DOMException
if
called
when
the
transaction
is
not
active
.
- 
request
=
index
.
get( query )
- 
Retrieves the value of the first record matching the given key or key range in query . If successful, request ’s resultwill be the value , orundefinedif there was no matching record .
- 
request
=
index
.
getKey( query )
- 
Retrieves the key of the first record matching the given key or key range in query . If successful, request ’s resultwill be the key , orundefinedif there was no matching record .
- 
request
=
index
.
getAll( query [, count ])
- 
Retrieves the values of the records matching the given key or key range in query (up to count if given). If successful, request ’s resultwill be an Array of the values .
- 
request
=
index
.
getAllKeys( query [, count ])
- 
Retrieves the keys of records matching the given key or key range in query (up to count if given). If successful, request ’s resultwill be an Array of the keys .
- 
request
=
index
.
count( query )
- 
Retrieves the number of records matching the given key or key range in query . If successful, request ’s resultwill be the count.
The
get(
query
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
If index or index ’s object store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
Let range be the result of converting a value to a key range with query and true. Rethrow any exceptions. 
- 
Let operation be an algorithm to run retrieve a referenced value from an index with the current Realm , index , and range . 
- 
Return the result (an IDBRequest) of running asynchronously execute a request with this and operation .
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
getKey(
query
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
If index or index ’s object store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
Let range be the result of converting a value to a key range with query and true. Rethrow any exceptions. 
- 
Let operation be an algorithm to run retrieve a value from an index with index and range . 
- 
Return the result (an IDBRequest) of running asynchronously execute a request with this and operation .
In all current engines.
Opera 35+ Edge 79+
Edge (Legacy) 18 IE None
Firefox for Android 44+ iOS Safari 10.3+ Chrome for Android 48+ Android WebView 48+ Samsung Internet 5.0+ Opera Mobile 35+
The
getAll(
query
,
count
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
If index or index ’s object store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
Let range be the result of converting a value to a key range with query . Rethrow any exceptions. 
- 
Let operation be an algorithm to run retrieve multiple referenced values from an index with the current Realm , index , range , and count if given. 
- 
Return the result (an IDBRequest) of running asynchronously execute a request with this and operation .
In all current engines.
Opera 35+ Edge 79+
Edge (Legacy) 18 IE None
Firefox for Android 🔰 44+ iOS Safari 10.3+ Chrome for Android 48+ Android WebView 48+ Samsung Internet 5.0+ Opera Mobile 35+
The
getAllKeys(
query
,
count
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
If index or index ’s object store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
Let range be the result of converting a value to a key range with query . Rethrow any exceptions. 
- 
Let operation be an algorithm to run retrieve multiple values from an index with index , range , and count if given. 
- 
Return the result (an IDBRequest) of running asynchronously execute a request with this and operation .
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
count(
query
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
If index or index ’s object store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
Let range be the result of converting a value to a key range with query . Rethrow any exceptions. 
- 
Let operation be an algorithm to run count the records in a range with index and range . 
- 
Return the result (an IDBRequest) of running asynchronously execute a request with this and operation .
TransactionInactiveError
"
DOMException
if
called
when
the
transaction
is
not
active
.
- 
request
=
index
.
openCursor([ query [, direction = "next"]])
- 
Opens a cursor over the records matching query , ordered by direction . If query is null, all records in index are matched. If successful, request ’s resultwill be anIDBCursorWithValue, or null if there were no matching records .
- 
request
=
index
.
openKeyCursor([ query [, direction = "next"]])
- 
Opens a cursor with key only flag set to true over the records matching query , ordered by direction . If query is null, all records in index are matched. If successful, request ’s resultwill be anIDBCursor, or null if there were no matching records .
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
openCursor(
query
,
direction
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
If index or index ’s object store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
Let range be the result of converting a value to a key range with query . Rethrow any exceptions. 
- 
Let cursor be a new cursor with its transaction set to transaction , undefined position , direction set to direction , got value flag set to false, undefined key and value , source set to index , range set to range , and key only flag set to false. 
- 
Let operation be an algorithm to run iterate a cursor with the current Realm and cursor . 
- 
Let request be the result of running asynchronously execute a request with this and operation . 
- 
Set cursor ’s request to request . 
- 
Return request . 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
openKeyCursor(
query
,
direction
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
If index or index ’s object store has been deleted, throw an " InvalidStateError"DOMException.
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
Let range be the result of converting a value to a key range with query . Rethrow any exceptions. 
- 
Let cursor be a new cursor with its transaction set to transaction , undefined position , direction set to direction , got value flag set to false, undefined key and value , source set to index , range set to range , and key only flag set to true. 
- 
Let operation be an algorithm to run iterate a cursor with the current Realm and cursor . 
- 
Let request be the result of running asynchronously execute a request with this and operation . 
- 
Set cursor ’s request to request . 
- 
Return request . 
4.7.
The
IDBKeyRange
interface
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView Yes Samsung Internet Yes Opera Mobile 14+
The
IDBKeyRange
interface
represents
a
key
range
.
[Exposed =(Window ,Worker )]interface {IDBKeyRange readonly attribute any lower ;readonly attribute any upper ;readonly attribute boolean lowerOpen ;readonly attribute boolean upperOpen ; // Static construction methods: [NewObject ]static IDBKeyRange only (any ); [value NewObject ]static IDBKeyRange lowerBound (any ,lower optional boolean =open false ); [NewObject ]static IDBKeyRange upperBound (any ,upper optional boolean =open false ); [NewObject ]static IDBKeyRange bound (any ,lower any ,upper optional boolean =lowerOpen false ,optional boolean =upperOpen false );boolean includes (any ); };key 
- 
range
.
lower
- 
Returns the range’s lower bound , or undefinedif none.
- 
range
.
upper
- 
Returns the range’s upper bound , or undefinedif none.
- 
range
.
lowerOpen
- 
Returns the range’s lower open flag . 
- 
range
.
upperOpen
- 
Returns the range’s upper open flag . 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView Yes Samsung Internet Yes Opera Mobile 14+
The
lower
getter
steps
are
to
return
the
result
of
converting
a
key
to
a
value
with
this
's
lower
bound
if
it
is
not
null,
or
undefined
otherwise.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView Yes Samsung Internet Yes Opera Mobile 14+
The
upper
getter
steps
are
to
return
the
result
of
converting
a
key
to
a
value
with
this
's
upper
bound
if
it
is
not
null,
or
undefined
otherwise.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView Yes Samsung Internet Yes Opera Mobile 14+
The
lowerOpen
getter
steps
are
to
return
this
's
lower
open
flag
.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView Yes Samsung Internet Yes Opera Mobile 14+
The
upperOpen
getter
steps
are
to
return
this
's
upper
open
flag
.
- 
range
=
IDBKeyRange.only( key )
- 
Returns a new IDBKeyRangespanning only key .
- 
range
=
IDBKeyRange.lowerBound( key [, open = false])
- 
Returns a new IDBKeyRangestarting at key with no upper bound. If open is true, key is not included in the range.
- 
range
=
IDBKeyRange.upperBound( key [, open = false])
- 
Returns a new IDBKeyRangewith no lower bound and ending at key . If open is true, key is not included in the range.
- 
range
=
IDBKeyRange.bound( lower , upper [, lowerOpen = false [, upperOpen = false]])
- 
Returns a new IDBKeyRangespanning from lower to upper . If lowerOpen is true, lower is not included in the range. If upperOpen is true, upper is not included in the range.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView Yes Samsung Internet Yes Opera Mobile 14+
The
only(
value
)
method
steps
are:
- 
Let key be the result of converting a value to a key with value . Rethrow any exceptions. 
- 
If key is invalid, throw a " DataError"DOMException.
- 
Create and return a new key range containing only key . 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView Yes Samsung Internet Yes Opera Mobile 14+
The
lowerBound(
lower
,
open
)
method
steps
are:
- 
Let lowerKey be the result of converting a value to a key with lower . Rethrow any exceptions. 
- 
If lowerKey is invalid, throw a " DataError"DOMException.
- 
Create and return a new key range with lower bound set to lowerKey , lower open flag set to open , upper bound set to null, and upper open flag set to true. 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView Yes Samsung Internet Yes Opera Mobile 14+
The
upperBound(
upper
,
open
)
method
steps
are:
- 
Let upperKey be the result of converting a value to a key with upper . Rethrow any exceptions. 
- 
If upperKey is invalid, throw a " DataError"DOMException.
- 
Create and return a new key range with lower bound set to null, lower open flag set to true, upper bound set to upperKey , and upper open flag set to open . 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView Yes Samsung Internet Yes Opera Mobile 14+
The
bound(
lower
,
upper
,
lowerOpen
,
upperOpen
)
method
steps
are:
- 
Let lowerKey be the result of converting a value to a key with lower . Rethrow any exceptions. 
- 
If lowerKey is invalid, throw a " DataError"DOMException.
- 
Let upperKey be the result of converting a value to a key with upper . Rethrow any exceptions. 
- 
If upperKey is invalid, throw a " DataError"DOMException.
- 
If lowerKey is greater than upperKey , throw a " DataError"DOMException.
- 
Create and return a new key range with lower bound set to lowerKey , lower open flag set to lowerOpen , upper bound set to upperKey and upper open flag set to upperOpen . 
- 
range
.
includes( key )
- 
Returns true if key is included in the range, and false otherwise. 
In all current engines.
Opera 39+ Edge 79+
Edge (Legacy) 18 IE None
Firefox for Android Yes iOS Safari 10.3+ Chrome for Android 52+ Android WebView 52+ Samsung Internet 6.0+ Opera Mobile 41+
The
includes(
key
)
method
steps
are:
- 
Let k be the result of converting a value to a key with key . Rethrow any exceptions. 
- 
If k is invalid, throw a " DataError"DOMException.
- 
Return true if k is in this range, and false otherwise. 
4.8.
The
IDBCursor
interface
In all current engines.
Opera 44+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 43+
Cursor
objects
implement
the
IDBCursor
interface.
There
is
only
ever
one
IDBCursor
instance
representing
a
given
cursor
.
There
is
no
limit
on
how
many
cursors
can
be
used
at
the
same
time.
[Exposed =(Window ,Worker )]interface {IDBCursor readonly attribute (IDBObjectStore or IDBIndex )source ;readonly attribute IDBCursorDirection direction ;readonly attribute any key ;readonly attribute any primaryKey ; [SameObject ]readonly attribute IDBRequest request ;undefined advance ([EnforceRange ]unsigned long );count undefined continue (optional any );key undefined continuePrimaryKey (any ,key any );primaryKey undefined close (); [NewObject ]IDBRequest update (any ); [value NewObject ]IDBRequest delete (); };enum {IDBCursorDirection ,"next" ,"nextunique" ,"prev" };"prevunique" 
- 
cursor
.
source
- 
Returns the IDBObjectStoreorIDBIndexthe cursor was opened from.
- 
cursor
.
direction
- 
Returns the direction ( "next","nextunique","prev"or"prevunique") of the cursor.
- 
cursor
.
key
- 
Returns the key of the cursor. Throws a " InvalidStateError"DOMExceptionif the cursor is advancing or is finished.
- 
cursor
.
primaryKey
- 
Returns the effective key of the cursor. Throws a " InvalidStateError"DOMExceptionif the cursor is advancing or is finished.
- 
cursor
.
request
- 
Returns the request that was used to obtain this cursor. 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
source
getter
steps
are
to
return
this
's
source
.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
direction
getter
steps
are
to
return
this
's
direction
.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
key
getter
steps
are
to
return
the
result
of
converting
a
key
to
a
value
with
the
cursor’s
current
key
.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
primaryKey
getter
steps
are
to
return
the
result
of
converting
a
key
to
a
value
with
the
cursor’s
current
effective
key
.
Opera 63+ Edge 79+
Edge (Legacy) None IE None
Firefox for Android None iOS Safari None Chrome for Android 76+ Android WebView 76+ Samsung Internet 12.0+ Opera Mobile 54+
The
request
getter
steps
are
to
return
this
's
request
.
success
event
will
be
fired
at
the
same
IDBRequest
returned
when
the
cursor
was
opened.
The
result
will
be
the
same
cursor
if
a
record
was
in
range,
or
undefined
otherwise.
If
called
while
the
cursor
is
already
advancing,
an
"
InvalidStateError
"
DOMException
will
be
thrown.
The
following
methods
throw
a
"
TransactionInactiveError
"
DOMException
if
called
when
the
transaction
is
not
active
.
- 
cursor
.
advance( count )
- 
Advances the cursor through the next count records in range. 
- 
cursor
.
continue()
- 
Advances the cursor to the next record in range. 
- 
cursor
.
continue( key )
- 
Advances the cursor to the next record in range matching or after key . 
- 
cursor
.
continuePrimaryKey( key , primaryKey )
- 
Advances the cursor to the next record in range matching or after key and primaryKey . Throws an " InvalidAccessError"DOMExceptionif the source is not an index .
- 
cursor
.
close()
- Signals that the cursor is no longer needed, and that any associated resources can be released. 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
advance(
count
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
If this 's source or effective object store has been deleted, throw an " InvalidStateError"DOMException.
- 
If this 's got value flag is false, indicatingfalse (indicating that the cursor is beingiterated oriterated, has iterated past its end, or thatclose()was called), then throw an "InvalidStateError"DOMException.
- 
Set this 's got value flag to false. 
- 
Set request ’s processed flag to false. 
- 
Set request ’s done flag to false. 
- 
Let operation be an algorithm to run iterate a cursor with the current Realm , this , and count . 
- 
Run asynchronously execute a request with this 's source , operation , and request . 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
continue(
key
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
If this 's source or effective object store has been deleted, throw an " InvalidStateError"DOMException.
- 
If this 's got value flag is false, indicatingfalse (indicating that the cursor is beingiterated oriterated, has iterated past its end, or thatclose()was called), then throw an "InvalidStateError"DOMException.
- 
If key is given, then: - 
Let r be the result of converting a value to a key with key . Rethrow any exceptions. 
- 
If r is invalid, throw a " DataError"DOMException.
- 
Let key be r . 
- 
If key is less than or equal to this 's position and this 's direction is "next"or"nextunique", then throw a "DataError"DOMException.
- 
If key is greater than or equal to this 's position and this 's direction is "prev"or"prevunique", then throw a "DataError"DOMException.
 
- 
- 
Set this 's got value flag to false. 
- 
Set request ’s processed flag to false. 
- 
Set request ’s done flag to false. 
- 
Let operation be an algorithm to run iterate a cursor with the current Realm , this , and key (if given). 
- 
Run asynchronously execute a request with this 's source , operation , and request . 
In all current engines.
Opera 45+ Edge 79+
Edge (Legacy) None IE None
Firefox for Android 51+ iOS Safari 10.3+ Chrome for Android 58+ Android WebView 58+ Samsung Internet 7.0+ Opera Mobile 43+
The
continuePrimaryKey(
key
,
primaryKey
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
If this 's source or effective object store has been deleted, throw an " InvalidStateError"DOMException.
- 
If this 's source is not an index throw an " InvalidAccessError"DOMException.
- 
If this 's direction is not "next"or"prev", throw an "InvalidAccessError"DOMException.
- 
If this 's got value flag is false, indicatingfalse (indicating that the cursor is beingiterated oriterated, has iterated past its end, or thatclose()was called), then throw an "InvalidStateError"DOMException.
- 
Let r be the result of converting a value to a key with key . Rethrow any exceptions. 
- 
If r is invalid, throw a " DataError"DOMException.
- 
Let key be r . 
- 
Let r be the result of converting a value to a key with primaryKey . Rethrow any exceptions. 
- 
If r is invalid, throw a " DataError"DOMException.
- 
Let primaryKey be r . 
- 
If key is less than this 's position and this 's direction is "next", throw a "DataError"DOMException.
- 
If key is greater than this 's position and this 's direction is "prev", throw a "DataError"DOMException.
- 
If key is equal to this 's position and primaryKey is less than or equal to this 's object store position and this 's direction is "next", throw a "DataError"DOMException.
- 
If key is equal to this 's position and primaryKey is greater than or equal to this 's object store position and this 's direction is "prev", throw a "DataError"DOMException.
- 
Set this 's got value flag to false. 
- 
Set request ’s processed flag to false. 
- 
Set request ’s done flag to false. 
- 
Let operation be an algorithm to run iterate a cursor with the current Realm , this , key , and primaryKey . 
- 
Run asynchronously execute a request with this 's source , operation , and request . 
The
close()
method
steps
are:
- Let transaction be this 's transaction . 
- If transaction ’s state is not active , then throw a " - TransactionInactiveError"- DOMException.
- If this 's source or effective object store has been deleted, then throw an " - InvalidStateError"- DOMException.
- If this 's got value flag is false (indicating that the cursor is being iterated, has iterated past its end, or that - close()was called), then throw an "- InvalidStateError"- DOMException.
- Set this 's got value flag to false. 
- If this 's source is an index , then set this 's object store position to undefined. 
- If this 's key only flag is false, then set this 's value to undefined. 
ReadOnlyError
"
DOMException
if
called
within
a
read-only
transaction
,
and
a
"
TransactionInactiveError
"
DOMException
if
called
when
the
transaction
is
not
active
.
- 
request
=
cursor
.
update( value )
- 
Updated the record pointed at by the cursor with a new value. Throws a " DataError"DOMExceptionif the effective object store uses in-line keys and the key would have changed.If successful, request ’s resultwill be the record 's key .
- 
request
=
cursor
.
delete()
- 
Delete the record pointed at by the cursor with a new value. If successful, request ’s resultwill beundefined.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
update(
value
)
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
If transaction is a read-only transaction , throw a " ReadOnlyError"DOMException.
- 
If this 's source or effective object store has been deleted, throw an " InvalidStateError"DOMException.
- 
If this 's got value flag is false, indicatingfalse (indicating that the cursor is beingiterated oriterated, has iterated past its end, or thatclose()was called), then throw an "InvalidStateError"DOMException.
- 
If this 's key only flag is true, throw an " InvalidStateError"DOMException.
- 
Let targetRealm be a user-agent defined Realm . 
- 
Let clone be a clone of value in targetRealm during transaction . Rethrow any exceptions. Why create a copy of the value?The value is serialized when stored. Treating it as a copy here allows other algorithms in this specification to treat it as an ECMAScript value, but implementations can optimize this if the difference in behavior is not observable.
- 
If this 's effective object store uses in-line keys , then: - 
Let kpk be the result of extracting a key from a value using a key path with clone and the key path of this 's effective object store . Rethrow any exceptions. 
- 
If kpk is failure, invalid, or not equal to this 's effective key , throw a " DataError"DOMException.
 
- 
- 
Let operation be an algorithm to run store a record into an object store with this 's effective object store , clone , this 's effective key , and false. 
- 
Return the result (an IDBRequest) of running asynchronously execute a request with this and operation .
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
delete()
method
steps
are:
- 
Let transaction be this 's transaction . 
- 
If transaction ’s state is not active , then throw a " TransactionInactiveError"DOMException.
- 
If transaction is a read-only transaction , throw a " ReadOnlyError"DOMException.
- 
If this 's source or effective object store has been deleted, throw an " InvalidStateError"DOMException.
- 
If this 's got value flag is false, indicatingfalse (indicating that the cursor is beingiterated oriterated, has iterated past its end, or thatclose()was called), then throw an "InvalidStateError"DOMException.
- 
If this 's key only flag is true, throw an " InvalidStateError"DOMException.
- 
Let operation be an algorithm to run delete records from an object store with this 's effective object store and this 's effective key . 
- 
Return the result (an IDBRequest) of running asynchronously execute a request with this and operation .
A
cursor
that
has
its
key
only
flag
set
to
false
implements
the
IDBCursorWithValue
interface
as
well.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView Yes Samsung Internet 1.5+ Opera Mobile 14+
[Exposed =(Window ,Worker )]interface :IDBCursorWithValue IDBCursor {readonly attribute any value ; };
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView Yes Samsung Internet Yes Opera Mobile 14+
The
value
getter
steps
are
to
return
this
's
current
value
.
4.9.
The
IDBTransaction
interface
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
Transaction objects implement the following interface:
[Exposed =(Window ,Worker )]interface :IDBTransaction EventTarget {readonly attribute DOMStringList objectStoreNames ;readonly attribute IDBTransactionMode mode ;readonly attribute IDBTransactionDurability durability ; [SameObject ]readonly attribute IDBDatabase db ;;readonly attribute DOMException ?error ;IDBObjectStore objectStore (DOMString );name (); ();undefined commit ();undefined abort (); // Event handlers:attribute EventHandler onabort ;attribute EventHandler oncomplete ;attribute EventHandler onerror ; };enum {IDBTransactionMode ,"readonly" ,"readwrite" };"versionchange" 
- 
transaction
.
objectStoreNames
- 
Returns a list of the names of object stores in the transaction’s scope . For an upgrade transaction this is all object stores in the database . 
- 
transaction
.
mode
- 
Returns the mode the transaction was created with ( "readonly"or"readwrite"), or"versionchange"for an upgrade transaction .
- 
transaction
.
durability
- 
Returns the durability hint the transaction was created with ( "strict","relaxed"), or"default").
- 
transaction
.
db
- 
Returns the transaction’s connection . 
- 
transaction
.
error
- 
If the transaction was aborted , returns the error (a DOMException) providing the reason.
IDBTransaction/objectStoreNames
In all current engines.
Opera 35+ Edge 79+
Edge (Legacy) None IE None
Firefox for Android Yes iOS Safari Yes Chrome for Android 48+ Android WebView 48+ Samsung Internet 5.0+ Opera Mobile 35+
The
objectStoreNames
getter
steps
are:
- 
Let names be a list of the names of the object stores in this 's scope . 
- 
Return the result (a DOMStringList) of creating a sorted name list with names .
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
mode
getter
steps
are
to
return
this
's
mode
.
The
durability
getter
steps
are
to
return
this
's
durability
hint
.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
db
getter
steps
are
to
return
this
's
connection
's
associated
database
.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android 25+ Android WebView 37+ Samsung Internet 1.5+ Opera Mobile 14+
The
error
getter
steps
are
to
return
this
's
error
,
or
null
if
none.
- 
transaction
.
objectStore( name )
- 
Returns an IDBObjectStorein the transaction 's scope .
- 
transaction
.
abort()
- 
Aborts the transaction. All pending requests will fail with a " AbortError"DOMExceptionand all changes made to the database will be reverted.
- 
transaction
.
commit()
- 
Attempts to commit the transaction. All pending requests will be allowed to complete, but no new requests will be accepted. This can be used to force a transaction to quickly finish, without waiting for pending requests to fire successevents before attempting to commit normally.The transaction will abort if a pending request fails, for example due to a constraint error. The successevents for successful requests will still fire, but throwing an exception in an event handler will not abort the transaction. Similarly,errorevents for failed requests will still fire, but callingpreventDefault()will not prevent the transaction from aborting.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
objectStore(
name
)
method
steps
are:
- 
If this 's state is finished , then throw an " InvalidStateError"DOMException.
- 
Let store be the object store named name in this 's scope , or throw a " NotFoundError"DOMExceptionif none.
- 
Return an object store handle associated with store and this . 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
abort()
method
steps
are:
- 
If this 's state is committing or finished , then throw an " InvalidStateError"DOMException.
- 
Set this 's state to inactive and run abort a transaction with this and null. 
Opera 63+ Edge 79+
Edge (Legacy) None IE None
Firefox for Android None iOS Safari None Chrome for Android 76+ Android WebView 76+ Samsung Internet 12.0+ Opera Mobile 54+
The
commit()
method
steps
are:
- 
If this 's state is not active , then throw an " InvalidStateError"DOMException.
- 
Run commit a transaction with this . 
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
onabort
attribute
is
an
event
handler
IDL
attribute
whose
event
handler
event
type
is
abort
.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
oncomplete
attribute
is
an
event
handler
IDL
attribute
whose
event
handler
event
type
is
complete
.
In all current engines.
Opera 15+ Edge 79+
Edge (Legacy) 12+ IE None
Firefox for Android 22+ iOS Safari 8+ Chrome for Android Yes Android WebView 37+ Samsung Internet Yes Opera Mobile 14+
The
onerror
attribute
is
an
event
handler
IDL
attribute
whose
event
handler
event
type
is
error
.
5. Algorithms
5.1. Opening a database
To open a database with origin which requested the database to be opened, a database name , a database version , and a request , run these steps:
- 
Let queue be the connection queue for origin and name . 
- 
Add request to queue . 
- 
Wait until all previous requests in queue have been processed. 
- 
Let db be the database named name in origin , or null otherwise. 
- 
If version is undefined, let version be 1 if db is null, or db ’s version otherwise. 
- 
If db is null, let db be a new database with name name , version 0 (zero), and with no object stores . If this fails for any reason, return an appropriate error (e.g. a " QuotaExceededError" or "UnknownError"DOMException).
- 
If db ’s version is greater than version , return a newly created " VersionError"DOMExceptionand abort these steps.
- 
Let connection be a new connection to db . 
- 
Set connection ’s version to version . 
- 
If db ’s version is less than version , then: - 
Let openConnections be the set of all connections , except connection , associated with db . 
- 
For each entry of openConnections that does not have its close pending flag set to true, queue a task to fire a version change event named versionchangeat entry with db ’s version and version .
- 
Wait for all of the events to be fired. 
- 
If any of the connections in openConnections are still not closed, queue a task to fire a version change event named blockedat request with db ’s version and version .
- 
Wait until all connections in openConnections are closed . 
- 
Run run an upgrade transaction using connection , version and request . 
- 
If connection was closed , return a newly created " AbortError"DOMExceptionand abort these steps.
- 
If the upgrade transaction was aborted, run the steps to close a database connection with connection , return a newly created " AbortError"DOMExceptionand abort these steps.
 
- 
- 
Return connection . 
5.2. Closing a database
To close a database connection with a connection object, and an optional forced flag , run these steps:
- 
Set connection ’s close pending flag to true. 
- 
If the forced flag is true, then for each transaction created using connection run abort a transaction with transaction and newly created " AbortError"DOMException.
- 
Wait for all transactions created using connection to complete. Once they are complete, connection is closed . 
- 
If the forced flag is true, then fire an event named closeat connection .
5.3. Deleting a database
To delete a database with the origin that requested the database to be deleted, a database name , and a request , run these steps:
- 
Let queue be the connection queue for origin and name . 
- 
Add request to queue . 
- 
Wait until all previous requests in queue have been processed. 
- 
Let db be the database named name in origin , if one exists. Otherwise, return 0 (zero). 
- 
Let openConnections be the set of all connections associated with db . 
- 
For each entry of openConnections that does not have its close pending flag set to true, queue a task to fire a version change event named versionchangeat entry with db ’s version and null.
- 
Wait for all of the events to be fired. 
- 
If any of the connections in openConnections are still not closed, queue a task to fire a version change event named blockedat request with db ’s version and null.
- 
Wait until all connections in openConnections are closed . 
- 
Let version be db ’s version . 
- 
Delete db . If this fails for any reason, return an appropriate error (e.g. " QuotaExceededError" or "UnknownError"DOMException).
- 
Return version . 
5.4. Committing a transaction
To commit a transaction with the transaction to commit, run these steps:
- 
Set transaction ’s state to committing . 
- 
Run the following steps in parallel : - 
Wait until every item in transaction ’s request list is processed . 
- 
If transaction ’s state is no longer committing , then terminate these steps. 
- 
Attempt to write any outstanding changes made by transaction to the database , considering transaction ’s durability hint . 
- 
If an error occurs while writing the changes to the database , then run abort a transaction with transaction and an appropriate type for the error, for example " QuotaExceededError" or "UnknownError"DOMException, and terminate these steps.
- 
Queue a task to run these steps: - 
If transaction is an upgrade transaction , then set transaction ’s connection 's associated database 's upgrade transaction to null. 
- 
Fire an event named completeat transaction .
- 
If transaction is an upgrade transaction , then let request be the request associated with transaction and set request ’s transaction to null. 
 
- 
 
- 
5.5. Aborting a transaction
To abort a transaction with the transaction to abort, and error , run these steps:
- 
All the changes made to the database by the transaction are reverted. For upgrade transactions this includes changes to the set of object stores and indexes , as well as the change to the version . Any object stores and indexes which were created during the transaction are now considered deleted for the purposes of other algorithms. 
- 
If transaction is an upgrade transaction , run the steps to abort an upgrade transaction with transaction . 
- 
If error is not null, set transaction ’s error to error . 
- 
For each request of transaction ’s request list , abort the steps to asynchronously execute a request for request , set request ’s processed flag to true, and queue a task to run these steps: - 
Set request ’s done flag to true. 
- 
Set request ’s result to undefined. 
- 
Set request ’s error to a newly created " AbortError"DOMException.
- 
Fire an event named errorat request with itsbubblesandcancelableattributes initialized to true.
 
- 
- 
Queue a task to run these steps: - 
If transaction is an upgrade transaction , then set transaction ’s connection 's associated database 's upgrade transaction to null. 
- 
Fire an event named abortat transaction with itsbubblesattribute initialized to true.
- 
If transaction is an upgrade transaction , then: - 
Let request be the open request associated with transaction . 
- 
Set request ’s transaction to null. 
- 
Set request ’s result to undefined. 
- 
Set request ’s processed flag to false. 
- 
Set request ’s done flag to false. 
 
- 
 
- 
5.6. Asynchronously executing a request
To asynchronously execute a request with the source object and an operation to perform on a database, and an optional request , run these steps:
These steps can be aborted at any point if the transaction the created request belongs to is aborted using the steps to abort a transaction .
- 
Let transaction be the transaction associated with source . 
- 
If request was not given, let request be a new request with source as source . 
- 
Add request to the end of transaction ’s request list . 
- 
Run these steps in parallel : - 
Wait until request is the first item in transaction ’s request list that is not processed . 
- 
Let result be the result of performing operation . 
- 
If result is an error and transaction ’s state is committing , then run abort a transaction with transaction and result , and terminate these steps. 
- 
If result is an error, then revert all changes made by operation . 
- 
Set request ’s processed flag to true. 
- 
Queue a task to run these steps: - 
Remove request from transaction ’s request list . 
- 
Set request ’s done flag to true. 
- 
If result is an error, then: - 
Set request ’s result to undefined. 
- 
Set request ’s error to result . 
- 
Fire an error event at request . 
 
- 
- 
Otherwise: - 
Set request ’s result to result . 
- 
Set request ’s error to undefined. 
- 
Fire a success event at request . 
 
- 
 
- 
 
- 
- 
Return request . 
5.7. Running an upgrade transaction
To run an upgrade transaction with connection (a connection ) which is used to update the database , a new version to be set for the database , and a request , run these steps:
- 
Let db be connection ’s database . 
- 
Let transaction be a new upgrade transaction with connection used as connection . 
- 
Set transaction ’s scope to connection ’s object store set . 
- 
Set db ’s upgrade transaction to transaction . 
- 
Start transaction . 
- 
Let old version be db ’s version . 
- 
Set db ’s version to version . This change is considered part of the transaction , and so if the transaction is aborted , this change is reverted. 
- 
Set request ’s processed flag to true. 
- 
Queue a task to run these steps: - 
Set request ’s result to connection . 
- 
Set request ’s transaction to transaction . 
- 
Set request ’s done flag to true. 
- 
Let didThrow be the result of firing a version change event named upgradeneededat request with old version and version .
- 
If didThrow is true, run abort a transaction with transaction and a newly created " AbortError"DOMException.
 
- 
- 
Wait for transaction to finish . 
5.8. Aborting an upgrade transaction
To abort an upgrade transaction with transaction , run these steps:
- 
Let connection be transaction ’s connection . 
- 
Let database be connection ’s database . 
- 
Set connection ’s version to database ’s version if database previously existed, or 0 (zero) if database was newly created. 
- 
Set connection ’s object store set to the set of object stores in database if database previously existed, or the empty set if database was newly created. 
- 
For each object store handle handle associated with transaction , including those for object stores that were created or deleted during transaction : - 
If handle ’s object store was not newly created during transaction , set handle ’s name to its object store 's name . 
- 
Set handle ’s index set to the set of indexes that reference its object store . 
 How is this observable?Although script cannot access an object store by using theobjectStore()method on anIDBTransactioninstance after the transaction is aborted, it can still have references toIDBObjectStoreinstances where thenameandindexNamesproperties can be queried.
- 
- 
For each index handle handle associated with transaction , including those for indexes that were created or deleted during transaction : - 
If handle ’s index was not newly created during transaction , set handle ’s name to its index 's name . 
 How is this observable?Although script cannot access an index by using theindex()method on anIDBObjectStoreinstance after the transaction is aborted, it can still have references toIDBIndexinstances where thenameproperty can be queried.
- 
5.9. Firing a success event
To fire a success event at a request , run these steps:
- 
Let event be the result of creating an event using Event.
- 
Set event ’s typeattribute to "success".
- 
Set event ’s bubblesandcancelableattributes to false.
- 
Let transaction be request ’s transaction . 
- 
Let legacyOutputDidListenersThrowFlag be initially false. 
- 
If transaction ’s state is inactive , then set transaction ’s state to active . 
- 
Dispatch event at request with legacyOutputDidListenersThrowFlag . 
- 
If transaction ’s state is active , then: 
- 
If legacyOutputDidListenersThrowFlag is true, then run abort a transaction with transaction and a newly created " AbortError"DOMException.
- 
If transaction ’s request list is empty, then run commit a transaction with transaction . 
 
5.10. Firing an error event
To fire an error event at a request , run these steps:
- 
Let event be the result of creating an event using Event.
- 
Set event ’s typeattribute to "error".
- 
Set event ’s bubblesandcancelableattributes to true.
- 
Let transaction be request ’s transaction . 
- 
Let legacyOutputDidListenersThrowFlag be initially false. 
- 
If transaction ’s state is inactive , then set transaction ’s state to active . 
- 
Dispatch event at request with legacyOutputDidListenersThrowFlag . 
- 
If transaction ’s state is active , then: 
- 
If legacyOutputDidListenersThrowFlag is true, then run abort a transaction with transaction and a newly created " AbortError"DOMExceptionand terminate these steps. This is done even if event ’s canceled flag is false.
- 
If event ’s canceled flag is false, then run abort a transaction using transaction and request 's error , and terminate these steps. 
- 
If transaction ’s request list is empty, then run commit a transaction with transaction . 
 
5.11. Clone a value
To make a clone of value in targetRealm during transaction , run these steps:
6. Database operations
This section describes various operations done on the data in object stores and indexes in a database . These operations are run by the steps to asynchronously execute a request .
6.1. Object store storage operation
To store a record into an object store with store , value , an optional key , and a no-overwrite flag , run these steps:
- 
If store uses a key generator , then: - 
If key is undefined, then: - 
Let key be the result of generating a key for store . 
- 
If key is failure, then this operation failed with a " ConstraintError"DOMException. Abort this algorithm without taking any further steps.
- 
If store also uses in-line keys , then run inject a key into a value using a key path with value , key and store ’s key path . 
 
- 
- 
Otherwise, run possibly update the key generator for store with key . 
 
- 
- 
If the no-overwrite flag was given to these steps and is true, and a record already exists in store with its key equal to key , then this operation failed with a " ConstraintError"DOMException. Abort this algorithm without taking any further steps.
- 
If a record already exists in store with its key equal to key , then remove the record from store using delete records from an object store . 
- 
Store a record in store containing key as its key and ! StructuredSerializeForStorage ( value ) as its value. The record is stored in the object store’s list of records such that the list is sorted according to the key of the records in ascending order. 
- 
For each index which references store : - 
Let index key be the result of extracting a key from a value using a key path with value , index ’s key path , and index ’s multiEntry flag . 
- 
If index key is an exception, or invalid, or failure, take no further actions for index , and continue these steps for the next index. 
- 
If index ’s multiEntry flag is false, or if index key is not an array key , and if index already contains a record with key equal to index key , and index ’s unique flag is true, then this operation failed with a " ConstraintError"DOMException. Abort this algorithm without taking any further steps.
- 
If index ’s multiEntry flag is true and index key is an array key , and if index already contains a record with key equal to any of the subkeys of index key , and index ’s unique flag is true, then this operation failed with a " ConstraintError"DOMException. Abort this algorithm without taking any further steps.
- 
If index ’s multiEntry flag is false, or if index key is not an array key then store a record in index containing index key as its key and key as its value. The record is stored in index ’s list of records such that the list is sorted primarily on the records keys, and secondarily on the records values, in ascending order. 
- 
If index ’s multiEntry flag is true and index key is an array key , then for each subkey of the subkeys of index key store a record in index containing subkey as its key and key as its value. The records are stored in index ’s list of records such that the list is sorted primarily on the records keys, and secondarily on the records values, in ascending order. 
 
- 
- 
Return key . 
6.2. Object store retrieval operations
To retrieve a value from an object store with targetRealm , store and range , run these steps:
- 
Let record be the first record in store ’s list of records whose key is in range , if any. 
- 
If record was not found, return undefined. 
- 
Let serialized be of record ’s value . 
- 
Return ! StructuredDeserialize ( serialized , targetRealm ). 
To retrieve multiple values from an object store with targetRealm , store , range and optional count , run these steps:
- 
If count is not given or is 0 (zero), let count be infinity. 
- 
Let records be a list containing the first count records in store ’s list of records whose key is in range . 
- 
Let list be an empty list . 
- 
For each record of records : - 
Let serialized be record ’s value . 
- 
Let entry be ! StructuredDeserialize ( serialized , targetRealm ). 
- 
Append entry to list . 
 
- 
To retrieve a key from an object store with store and range , run these steps:
- 
Let record be the first record in store ’s list of records whose key is in range , if any. 
- 
If record was not found, return undefined. 
- 
Return the result of converting a key to a value with record ’s key. 
To retrieve multiple keys from an object store with store , range and optional count , run these steps:
- 
If count is not given or is 0 (zero), let count be infinity. 
- 
Let records be a list containing the first count records in store ’s list of records whose key is in range . 
- 
Let list be an empty list . 
- 
For each record of records : - 
Let entry be the result of converting a key to a value with record ’s key. 
- 
Append entry to list . 
 
- 
6.3. Index retrieval operations
To retrieve a referenced value from an index with targetRealm , index and range , run these steps:
- 
Let record be the first record in index ’s list of records whose key is in range , if any. 
- 
If record was not found, return undefined. 
- 
Let serialized be record ’s referenced value . 
- 
Return ! StructuredDeserialize ( serialized , targetRealm ). 
To retrieve multiple referenced values from an index with targetRealm , index , range and optional count , run these steps:
- 
If count is not given or is 0 (zero), let count be infinity. 
- 
Let records be a list containing the first count records in index ’s list of records whose key is in range . 
- 
Let list be an empty list . 
- 
For each record of records : - 
Let serialized be record ’s referenced value . 
- 
Let entry be ! StructuredDeserialize ( serialized , targetRealm ). 
- 
Append entry to list . 
 
- 
To retrieve a value from an index with index and range , run these steps:
- 
Let record be the first record in index ’s list of records whose key is in range , if any. 
- 
If record was not found, return undefined. 
- 
Return the result of converting a key to a value with record ’s value . 
To retrieve multiple values from an index with index , range and optional count , run these steps:
- 
If count is not given or is 0 (zero), let count be infinity. 
- 
Let records be a list containing the first count records in index ’s list of records whose key is in range . 
- 
Let list be an empty list . 
- 
For each record of records : - 
Let entry be the result of converting a key to a value with record ’s value. 
- 
Append entry to list . 
 
- 
6.4. Object store deletion operation
To delete records from an object store with store and range , run these steps:
- 
Remove all records, if any, from store ’s list of records with key in range . 
- 
For each index which references store , remove every record from index ’s list of records whose value is in range , if any such records exist. 
- 
Return undefined. 
6.5. Record counting operation
To count the records in a range with source and range , run these steps:
- 
Let count be the number of records, if any, in source ’s list of records with key in range . 
- 
Return count . 
6.6. Object store clear operation
To clear an object store with store , run these steps:
6.7. Cursor iteration operation
To iterate a cursor with targetRealm , cursor , an optional key and primaryKey to iterate to, and an optional count , run these steps:
- 
Let source be cursor ’s source . 
- 
Let direction be cursor ’s direction . 
- 
Assert : if primaryKey is given, source is an index and direction is "next"or"prev".
- 
Let records be the list of records in source . 
- 
Let range be cursor ’s range . 
- 
Let position be cursor ’s position . 
- 
Let object store position be cursor ’s object store position . 
- 
If count is not given, let count be 1. 
- 
While count is greater than 0: - 
Switch on direction : - 
"next"
- 
Let found record be the first record in records which satisfy all of the following requirements: - 
If key is defined, the record’s key is greater than or equal to key . 
- 
If primaryKey is defined, the record’s key is equal to key and the record’s value is greater than or equal to primaryKey , or the record’s key is greater than key . 
- 
If position is defined, and source is an object store , the record’s key is greater than position . 
- 
If position is defined, and source is an index , the record’s key is equal to position and the record’s value is greater than object store position or the record’s key is greater than position . 
- 
The record’s key is in range . 
 
- 
- 
"nextunique"
- 
Let found record be the first record in records which satisfy all of the following requirements: - 
If key is defined, the record’s key is greater than or equal to key . 
- 
If position is defined, the record’s key is greater than position . 
- 
The record’s key is in range . 
 
- 
- 
"prev"
- 
Let found record be the last record in records which satisfy all of the following requirements: - 
If key is defined, the record’s key is less than or equal to key . 
- 
If primaryKey is defined, the record’s key is equal to key and the record’s value is less than or equal to primaryKey , or the record’s key is less than key . 
- 
If position is defined, and source is an object store , the record’s key is less than position . 
- 
If position is defined, and source is an index , the record’s key is equal to position and the record’s value is less than object store position or the record’s key is less than position . 
- 
The record’s key is in range . 
 
- 
- 
"prevunique"
- 
Let temp record be the last record in records which satisfy all of the following requirements: - 
If key is defined, the record’s key is less than or equal to key . 
- 
If position is defined, the record’s key is less than position . 
- 
The record’s key is in range . 
 If temp record is defined, let found record be the first record in records whose key is equal to temp record ’s key . 
- 
 
- 
- 
If found record is not defined, then: - 
Set cursor ’s key to undefined. 
- 
If source is an index , set cursor ’s object store position to undefined. 
- 
If cursor ’s key only flag is false, set cursor ’s value to undefined. 
- 
Return null. 
 
- 
- 
Let position be found record ’s key. 
- 
If source is an index , let object store position be found record ’s value. 
- 
Decrease count by 1. 
 
- 
- 
Set cursor ’s position to position . 
- 
If source is an index , set cursor ’s object store position to object store position . 
- 
Set cursor ’s key to found record ’s key. 
- 
If cursor ’s key only flag is false, then: - 
Let serialized be found record ’s referenced value . 
- 
Set cursor ’s value to ! StructuredDeserialize ( serialized , targetRealm ) 
 
- 
- 
Set cursor ’s got value flag to true. 
- 
Return cursor . 
7. ECMAScript binding
This section defines how key values defined in this specification are converted to and from ECMAScript values, and how they may be extracted from and injected into ECMAScript values using key paths . This section references types and algorithms and uses some algorithm conventions from the ECMAScript Language Specification. [ECMA-262] Conversions not detailed here are defined in [WEBIDL] .
7.1. Extract a key from a value
To extract a key from a value using a key path with value , keyPath and an optional multiEntry flag , run the following steps. The result of these steps is a key , invalid, or failure, or the steps may throw an exception.
- 
Let r be the result of evaluating a key path on a value with value and keyPath . Rethrow any exceptions. 
- 
If r is failure, return failure. 
- 
Let key be the result of converting a value to a key with r if the multiEntry flag is false, and the result of converting a value to a multiEntry key with r otherwise. Rethrow any exceptions. 
- 
If key is invalid, return invalid. 
- 
Return key . 
To evaluate a key path on a value with value and keyPath , run the following steps. The result of these steps is an ECMAScript value or failure, or the steps may throw an exception.
- 
If keyPath is a list of strings, then: - 
Let result be a new Array object created as if by the expression [].
- 
Let i be 0. 
- 
For each item of keyPath : - 
Let key be the result of recursively evaluating a key path on a value with item and value . 
- 
Assert : key is not an abrupt completion . 
- 
If key is failure, abort the overall algorithm and return failure. 
- 
Let status be CreateDataProperty ( result , p , key ). 
- 
Assert : status is true. 
- 
Increase i by 1. 
 
- 
- 
Return result . 
 
- 
- 
If keyPath is the empty string, return value and skip the remaining steps. 
- 
Let identifiers be the result of strictly splitting keyPath on U+002E FULL STOP characters (.). 
- 
For each identifier of identifiers , jump to the appropriate step below: - 
If
Type
(
value
)
is
String,
and
identifier
is
"
length"
- 
Let value be a Number equal to the number of elements in value . 
- 
If
value
is
an
Array
and
identifier
is
"
length"
- 
If
value
is
a
Bloband identifier is "size"
- 
Let value be a Number equal to value ’s size.
- 
If
value
is
a
Bloband identifier is "type"
- 
Let value be a String equal to value ’s type.
- 
If
value
is
a
Fileand identifier is "name"
- 
Let value be a String equal to value ’s name.
- 
If
value
is
a
Fileand identifier is "lastModified"
- 
Let value be a Number equal to value ’s lastModified.
- Otherwise
- 
- 
If Type ( value ) is not Object, return failure. 
- 
Let hop be ! HasOwnProperty ( value , identifier ). 
- 
If hop is false, return failure. 
- 
If value is undefined, return failure. 
 
- 
 
- 
If
Type
(
value
)
is
String,
and
identifier
is
"
- 
Assert : value is not an abrupt completion . 
- 
Return value . 
7.2. Inject a key into a value
To check that a key could be injected into a value with value and a keyPath , run the following steps. The result of these steps is either true or false.
To inject a key into a value using a key path with value , a key and a keyPath , run these steps:
- 
Let identifiers be the result of strictly splitting keyPath on U+002E FULL STOP characters (.). 
- 
Assert : identifiers is not empty. 
- 
Let last be the last item of identifiers and remove it from the list. 
- 
For each remaining identifier of identifiers : 
- 
Let hop be ! HasOwnProperty ( value , identifier ). 
- 
If hop is false, then: - 
Let o be a new Object created as if by the expression ({}).
- 
Let status be CreateDataProperty ( value , identifier , o ). 
- 
Assert : status is true. 
 
- 
 
- 
Let keyValue be the result of converting a key to a value with key . 
- 
Let status be CreateDataProperty ( value , last , keyValue ). 
- 
Assert : status is true. 
7.3. Convert a key to a value
To convert a key to a value with key , run the following steps. The steps return an ECMAScript value.
- 
Let type be key ’s type . 
- 
Let value be key ’s value . 
- 
Switch on type : - number
- 
Return an ECMAScript Number value equal to value 
- string
- 
Return an ECMAScript String value equal to value 
- date
- 
- 
Let date be the result of executing the ECMAScript Date constructor with the single argument value . 
- 
Assert : date is not an abrupt completion . 
- 
Return date . 
 
- 
- binary
- 
- 
Let len be value ’s length . 
- 
Let buffer be the result of executing the ECMAScript ArrayBuffer constructor with len . 
- 
Assert : buffer is not an abrupt completion . 
- 
Set the entries in buffer ’s [[ArrayBufferData]] internal slot to the entries in value . 
- 
Return buffer . 
 
- 
- array
- 
- 
Let array be the result of executing the ECMAScript Array constructor with no arguments. 
- 
Assert : array is not an abrupt completion . 
- 
Let len be value ’s size . 
- 
Let index be 0. 
- 
While index is less than len : - 
Let entry be the result of converting a key to a value with value [ index ]. 
- 
Let status be CreateDataProperty ( array , index , entry ). 
- 
Assert : status is true. 
- 
Increase index by 1. 
 
- 
- 
Return array . 
 
- 
 
7.4. Convert a value to a key
To convert a value to a key with an ECMAScript value input , and an optional set seen , run the following steps. The result of these steps is a key or invalid, or the steps may throw an exception.
- 
If seen was not given, then let seen be a new empty set . 
- 
If seen contains input , then return invalid. 
- 
Jump to the appropriate step below: - If Type ( input ) is Number
- If input is a Date (has a [[DateValue]] internal slot)
- If Type ( input ) is String
- If input is a buffer source type
- 
- 
Let bytes be the result of getting a copy of the bytes held by the buffer source input . Rethrow any exceptions. 
 
- 
- If input is an Array exotic object
- 
- 
Append input to seen . 
- 
Let keys be a new empty list. 
- 
Let index be 0. 
- 
While index is less than len : - 
Let hop be ? HasOwnProperty ( input , index ). 
- 
If hop is false, return invalid. 
- 
Let key be the result of converting a value to a key with arguments entry and seen . 
- 
ReturnIfAbrupt ( key ). 
- 
If key is invalid abort these steps and return invalid. 
- 
Append key to keys . 
- 
Increase index by 1. 
 
- 
 
- Otherwise
- 
Return invalid. 
 
To convert a value to a multiEntry key with an ECMAScript value input , run the following steps. The result of these steps is a key or invalid, or the steps may throw an exception.
- 
If input is an Array exotic object , then: 
- 
Let seen be a new set containing only input . 
- 
Let keys be a new empty list . 
- 
Let index be 0. 
- 
While index is less than len : - 
Let entry be Get ( input , index ). 
- 
If entry is not an abrupt completion , then: - 
Let key be the result of converting a value to a key with arguments entry and seen . 
- 
If key is not invalid or an abrupt completion , and there is no item in keys equal to key , then append key to keys . 
 
- 
- 
Increase index by 1. 
 
- 
 
- 
Otherwise, return the result of converting a value to a key with argument input . Rethrow any exceptions. 
8. Privacy considerations
This section is non-normative.
8.1. User tracking
A third-party host (or any object capable of getting content distributed to multiple sites) could use a unique identifier stored in its client-side database to track a user across multiple sessions, building a profile of the user’s activities. In conjunction with a site that is aware of the user’s real id object (for example an e-commerce site that requires authenticated credentials), this could allow oppressive groups to target individuals with greater accuracy than in a world with purely anonymous Web usage.
There are a number of techniques that can be used to mitigate the risk of user tracking:
- Blocking third-party storage
- 
User agents may restrict access to the database objects to scripts originating at the domain of the top-level document of the browsing context , for instance denying access to the API for pages from other domains running in iframes.
- Expiring stored data
- 
User agents may automatically delete stored data after a period of time. This can restrict the ability of a site to track a user, as the site would then only be able to track the user across multiple sessions when she authenticates with the site itself (e.g. by making a purchase or logging in to a service). However, this also puts the user’s data at risk. 
- Treating persistent storage as cookies
- 
User agents should present the database feature to the user in a way that associates them strongly with HTTP session cookies. [COOKIES] This might encourage users to view such storage with healthy suspicion. 
- Site-specific safe-listing of access to databases
- 
User agents may require the user to authorize access to databases before a site can use the feature. 
- Origin-tracking of stored data
- 
User agents may record the origins of sites that contained content from third-party origins that caused data to be stored. If this information is then used to present the view of data currently in persistent storage, it would allow the user to make informed decisions about which parts of the persistent storage to prune. Combined with a blocklist ("delete this data and prevent this domain from ever storing data again"), the user can restrict the use of persistent storage to sites that she trusts. 
- Shared blocklists
- 
User agents may allow users to share their persistent storage domain blocklists. This would allow communities to act together to protect their privacy. 
While these suggestions prevent trivial use of this API for user tracking, they do not block it altogether. Within a single domain, a site can continue to track the user during a session, and can then pass all this information to the third party along with any identifying information (names, credit card numbers, addresses) obtained by the site. If a third party cooperates with multiple sites to obtain such information, a profile can still be created.
However, user tracking is to some extent possible even with no cooperation from the user agent whatsoever, for instance by using session identifiers in URLs, a technique already commonly used for innocuous purposes but easily repurposed for user tracking (even retroactively). This information can then be shared with other sites, using visitors' IP addresses and other user-specific data (e.g. user-agent headers and configuration settings) to combine separate sessions into coherent user profiles.
8.2. Cookie resurrection
If the user interface for persistent storage presents data in the persistent storage features described in this specification separately from data in HTTP session cookies, then users are likely to delete data in one and not the other. This would allow sites to use the two features as redundant backup for each other, defeating a user’s attempts to protect his privacy.
8.3. Sensitivity of data
User agents should treat persistently stored data as potentially sensitive; it is quite possible for e-mails, calendar appointments, health records, or other confidential documents to be stored in this mechanism.
To this end, user agents should ensure that when deleting data, it is promptly deleted from the underlying storage.
9. Security considerations
9.1. DNS spoofing attacks
Because of the potential for DNS spoofing attacks, one cannot guarantee that a host claiming to be in a certain domain really is from that domain. To mitigate this, pages can use TLS. Pages using TLS can be sure that only pages using TLS that have certificates identifying them as being from the same domain can access their databases.
9.2. Cross-directory attacks
Different
authors
sharing
one
host
name,
for
example
users
hosting
content
on
geocities.com
,
all
share
one
set
of
databases.
There is no feature to restrict the access by pathname. Authors on shared hosts are therefore recommended to avoid using these features, as it would be trivial for other authors to read the data and overwrite it.
9.3. Implementation risks
The two primary risks when implementing these persistent storage features are letting hostile sites read information from other domains, and letting hostile sites write information that is then read from other domains.
Letting third-party sites read data that is not supposed to be read from their domain causes information leakage , For example, a user’s shopping wish list on one domain could be used by another domain for targeted advertising; or a user’s work-in-progress confidential documents stored by a word-processing site could be examined by the site of a competing company.
Letting third-party sites write data to the persistent storage of other domains can result in information spoofing , which is equally dangerous. For example, a hostile site could add records to a user’s wish list; or a hostile site could set a user’s session identifier to a known ID that the hostile site can then use to track the user’s actions on the victim site.
Thus, strictly following the origin model described in this specification is important for user security.
If
origins
or
database
names
are
used
to
construct
paths
for
persistence
to
a
file
system
they
must
be
appropriately
escaped
to
prevent
an
adversary
from
accessing
information
from
other
origins
using
relative
paths
such
as
"
../
".
9.4. Persistence risks
Practical implementations will persist data to a non-volatile storage medium. Data will be serialized when stored and deserialized when retrieved, although the details of the serialization format will be user-agent specific. User agents are likely to change their serialization format over time. For example, the format may be updated to handle new data types, or to improve performance. To satisfy the operational requirements of this specification, implementations must therefore handle older serialization formats in some way. Improper handling of older data can result in security issues. In addition to basic serialization concerns, serialized data could encode assumptions which are not valid in newer versions of the user agent.
A practical example of this is the RegExp type. The StructuredSerializeForStorage operation allows serializing RegExp objects. A typical user agent will compile a regular expression into native machine instructions, with assumptions about how the input data is passed and results returned. If this internal state was serialized as part of the data stored to the database, various problems could arise when the internal representation was later deserialized. For example, the means by which data was passed into the code could have changed. Security bugs in the compiler output could have been identified and fixed in updates to the user agent, but remain in the serialized internal state.
User agents must identify and handle older data appropriately. One approach is to include version identifiers in the serialization format, and to reconstruct any internal state from script-visible state when older data is encountered.
10. Accessibility considerations
This section is non-normative.
The API described by this specification has limited accesibility considerations:
- 
It does not provide for visual rendering of content, or control over color. 
- 
It does not provide features to accept user input. 
- 
It does not provide user interaction features. 
- 
It does not define document semantics. 
- 
It does not provide time-based visual media. 
- 
It does not allow time limits. 
- 
It does not directly provide content for end-users, either in textual, graphical or other or non-textual form. 
- 
It does not define a transmission protocol. 
The
API
does
allow
storage
of
structured
content.
Textual
content
can
be
stored
as
strings.
Support
exists
in
the
API
for
developers
to
store
alternative
non-textual
content
such
as
images
or
audio
as
Blob
,
File
,
or
ImageData
objects.
Developers
producing
dynamic
content
applications
using
the
API
should
ensure
that
the
content
is
accessible
to
users
with
a
variety
of
technologies
and
needs.
While the API itself does not define a specific mechanism for it, storage of structured content also allows developers to store internationalized content, using different records or structure within records to hold language alternatives.
The API does not define or require any a user agent to generate a user interface to enable interaction with the API. User agents may optionally provide user interface elements to support the API. Examples include prompts to users when additional storage quota is required, functionality to observe storage used by particular web sites, or tools specific to the API’s storage such as inspecting, modifying, or deleting records. Any such user interface elements must be designed with accessibility tools in mind. For example, a user interface presenting the fraction of storage quota used in graphical form must also provide the same data to tools such as screen readers.
11. Revision history
This section is non-normative.
The following is an informative summary of the changes since the last publication of this specification. A complete revision history can be found here . For the revision history of the first edition, see that document’s Revision History . For the revision history of the second edition, see that document’s Revision History .
- 
The cleanup Indexed Database transactions algorithm now returns a value for integration with other specs. ( PR #232 ) 
- 
Updated partial interface definition since WindowOrWorkerGlobalScopeis now amixin( PR #238 ).
- 
Added databases()method. ( Issue #31 )
- 
Added commit()method. ( Issue #234 )
- 
Added requestattribute. ( Issue #255 )
- 
Removed handling for nonstandard lastModifiedDateproperty ofFileobjects. ( Issue #215 )
- 
Remove escaping includes()method. ( Issue #294 )
- 
Restrict array keys to Array exotic objects (i.e. disallow proxies). ( Issue #309 ) 
- 
Transactions are now temporarily made inactive during clone operations. 
- 
Added durabilityoption anddurabilityattribute. ( Issue #50 )
- 
Specified § 2.7.2 Transaction scheduling more precisely and disallow starting read/write transactions while read-only transactions with overlapping scope are running. ( Issue #253 ) 
- 
Added Accessibility considerations section. ( Issue #327 ) 
- 
Used [infra] 's list sorting definition. ( Issue #346 ) 
- 
Added close()method forIDBCursor. ( Issue #185 )
12. Acknowledgements
This section is non-normative.
Special thanks to Nikunj Mehta, the original author of the first edition, and Jonas Sicking, Eliot Graff, Andrei Popescu, and Jeremy Orlow, additional editors of the first edition.
Garret Swart was extremely influential in the design of this specification.
Thanks to Tab Atkins, Jr. for creating and maintaining Bikeshed , the specification authoring tool used to create this document, and for his general authoring advice.
Special thanks to Chris Anderson, Jake Archibald, Yannic Bonenberger, Andreas Butler, Pablo Castro, Victor Costan, Kristof Degrave, Domenic Denicola, Jake Drew, Ben Dilts, João Eiras, Alec Flett, Dana Florescu, David Grogan, Israel Hilerio, Jerome Hode, Kyle Huey, Philip Jägenstedt, Laxminarayan G Kamath A, Anne van Kesteren, Adam Klein, Marijn Kruisselbrink, Tobie Langel, Kang-Hao Lu, Andrea Marchesini, Josh Matthews, Glenn Maynard, Isiah Meadows, Ms2ger, Odin Omdal, Danillo Paiva, Olli Pettay, Addison Phillips, Simon Pieters, Anthony Ramine, Yonathan Randolph, Arun Ranganathan, Kagami Sascha Rosylight, Margo Seltzer, Maciej Stachowiak, Andrew Sutherland, Yaron Tausky, Bevis Tseng, Ben Turner, Kyaw Tun, Adrienne Walker, Hans Wennborg, Shawn Wilsher, Brett Zamir, Boris Zbarsky, Zhiqiang Zhang, and Kris Zyp, all of whose feedback and suggestions have led to improvements to this specification.