IDBIndex
IndexedDB API の IDBIndex インターフェイスは、データベース内のインデックスへの非同期アクセスを提供します。インデックスはオブジェクトストアの一種で、参照先オブジェクトストアと呼ばれる別のオブジェクトストア内のレコードを検索するためのものです。データを取り出すためにこのインターフェイスを使用します。
オブジェクトストア内のレコードは、主キーを使用して取り出すことも、インデックスを使用して取り出すこともできます。インデックスにより、オブジェクトストア内のレコードに格納されている主キー以外の値の性質を用いてオブジェクトストアからレコードを検索できるようになります。
インデックスは永続的なキー-値ストレージで、そのレコードの値の部分は参照先オブジェクトストア内のレコードのキーの部分になります。参照先オブジェクトストアでレコードが挿入・更新・削除されると、そのたびにインデックス内でもレコードが自動で作成されます。あるインデックス内のレコードはそれぞれ参照先オブジェクトストア内のレコード 1 個だけを指すことができますが、複数のインデックスが同じオブジェクトストアを参照することができます。オブジェクトストアが変更されると、そのオブジェクトストアを参照する全てのインデックスが自動で更新されます。
ある範囲に含まれるキーの集合を得ることができます。詳しくは、IDBKeyRange を参照してください。
注: この機能は Web Worker 内で利用可能です
インスタンスプロパティ
IDBIndex.isAutoLocale(en-US) 読取専用 Non-standard Experimental-
インデックスの作成時に
localeの値がautoに設定されたかを表すboolean値を返します。(createIndex()(en-US) の引数options(en-US) を参照してください) IDBIndex.locale(en-US) 読取専用 Non-standard Experimental-
作成時に
localeの値が指定されていれば、インデックスのロケール (たとえばen-USやpl) を返します。(createIndex()(en-US) の引数options(en-US) を参照してください) IDBIndex.name(en-US)-
このインデックスの名前です。
IDBIndex.objectStore(en-US) 読取専用-
このインデックスが参照するオブジェクトストアの名前です。
IDBIndex.keyPath(en-US) 読取専用-
このインデックスのキーパスです。
nullである場合は、このインデックスは自動で作成されません。 IDBIndex.multiEntry(en-US) 読取専用-
インデックスのキーパスを評価した結果が配列になったとき、インデックスがどのようにふるまうかを変更します。
trueの場合は、インデックスにキーの配列内の各アイテムに対応するレコードをそれぞれ作成します。falseの場合は、配列であるキーに対応するレコード 1 個を作成します。 IDBIndex.unique(en-US) 読取専用-
trueの場合は、このインデックスはあるキーに対応する値の重複を許しません。
インスタンスメソッド
EventTarget から継承します。
IDBIndex.count()(en-US)-
IDBRequestオブジェクトを返し、別のスレッドでキーの範囲に含まれるレコードの数を返します。 IDBIndex.get()(en-US)-
IDBRequestオブジェクトを返し、別のスレッドで参照先オブジェクトストア内の指定されたキーに対応する値、もしくはkeyがIDBKeyRangeのときは対応する最初の値を検索します。 IDBIndex.getKey()(en-US)-
IDBRequestオブジェクトを返し、指定されたキーに対応する主キー、もしくはkeyがIDBKeyRangeのときは対応する最初の主キーを別のスレッドで検索します。 IDBIndex.getAll()(en-US)-
IDBRequestオブジェクトを返し、指定されたキー、もしくはkeyがIDBKeyRangeの場合はキーの範囲に対応する参照先オブジェクトストア内の全ての値を別のスレッドで検索します。 IDBIndex.getAllKeys()(en-US)-
IDBRequestオブジェクトを返し、指定されたキー、もしくはkeyがIDBKeyRangeの場合はキーの範囲に対応する参照先オブジェクトストア内の全てのキーを別のスレッドで検索します。 IDBIndex.openCursor()(en-US)-
IDBRequestオブジェクトを返し、指定されたキーの範囲を走査するためのカーソルを別のスレッドで作成します。 IDBIndex.openKeyCursor()(en-US)-
IDBRequestオブジェクトを返し、指定されたキーの範囲をこのインデックスの順番で走査するためのカーソルを別のスレッドで作成します。
例
以下の例では、トランザクションとオブジェクトストアを開き、シンプルな連絡先データベースからインデックス lName を取得します。そして、IDBIndex.openCursor (en-US) を用いてそのインデックスで基本的なカーソルを開きます。これは、返されるレコードが主キーではなくこのインデックスによりソートされること以外、IDBObjectStore.openCursor (en-US) を用いて ObjectStore で直接カーソルを開いたときと同じように動作します。
最後に、レコードを走査し、データを HTML テーブルに追加します。動く例全体は、IndexedDB-examples demo レポジトリを参照してください。(動く例を見る)
js
function displayDataByIndex() {
tableEntry.innerHTML = '';
const transaction = db.transaction(['contactsList'], 'readonly');
const objectStore = transaction.objectStore('contactsList');
const myIndex = objectStore.index('lName');
myIndex.openCursor().onsuccess = (event) => {
const cursor = event.target.result;
if (cursor) {
const tableRow = document.createElement('tr');
tableRow.innerHTML = `<td>${cursor.value.id}</td>`
+ `<td>${cursor.value.lName}</td>`
+ `<td>${cursor.value.fName}</td>`
+ `<td>${cursor.value.jTitle}</td>`
+ `<td>${cursor.value.company}</td>`
+ `<td>${cursor.value.eMail}</td>`
+ `<td>${cursor.value.phone}</td>`
+ `<td>${cursor.value.age}</td>`;
tableEntry.appendChild(tableRow);
cursor.continue();
} else {
console.log('全エントリーを表示しました。');
}
};
};
仕様書
| Specification |
|---|
| Indexed Database API 3.0 # index-interface |
ブラウザーの互換性
BCD tables only load in the browser
関連情報
- IndexedDB の使用
- トランザクションの開始:
IDBDatabase - トランザクションの使用:
IDBTransaction - キーの範囲の設定:
IDBKeyRange - データの取得と変更:
IDBObjectStore - カーソルの使用:
IDBCursor - リファレンス例: To-do Notifications (動く例を見る)