Skip to content

Table.where()

David Fahlander edited this page Nov 25, 2016 · 15 revisions

Start filtering the object store by creating a WhereClause instance.

Syntax

table.where(indexOrPrimaryKey)

// Dexie 2.0.0:
table.where({keyPath1: value1, keyPath2: value2, ...});

Parameters

indexOrPrimaryKey: String Name of an index or primary key registered in Version.stores(). The special string ":id" represents the primary key.
keyPath1, keyPath2, ... Strings identifying keyPath to filter on
value1, value2, ... Values to match

Description

If a string was provided, this method returns a WhereClause based on given index or primary key. The returned WhereClause can be used to build a query on how to extract objects from the database using any of the methods in WhereClause.

If a plain object containing criterias was provided, this method returns a Collection filtered using given criterias. If providing a single criteria, the keyPath must match with an index. If providing multiple criterias, it is recommended to have a compound index containing all of the keyPath (in arbritary order), but it is not required. If no compound index, at least one of the keyPaths must match a simple index. If Dexie.debug=true and not having compound index of all provided keyPaths, a console.warn() will give a hint on how to index this query properly.

Return Value

WhereClause if string was provided

Collection if object was provided.

Sample

db.friends.where("name").equalsIgnoreCase("david").each(function (friend) {
    console.log("Found: " + friend.name + ". Phone: " + friend.phoneNumber);
}).catch(function (error) {
    console.error(error);
});
db.friends.where({name: "David"}).each(friends => {
    console.log("Found: " + friend.name + ". Phone: " + friend.phoneNumber);
}).catch(error => {
    console.error(error.stack || error);
});

See Also

WhereClause

Clone this wiki locally