IDBDatabase.transaction()
IDBDatabase インターフェイスの transaction メソッドは、オブジェクトストアへのアクセスに利用できる IDBTransaction.objectStore (en-US) メソッドを含むトランザクションオブジェクト (IDBTransaction) を即座に返します。
注: この機能は Web Worker 内で利用可能です
構文
js
transaction(storeNames)
transaction(storeNames, mode)
transaction(storeNames, mode, options)
引数
storeNames-
新しいトランザクションの対象となるオブジェクトストアの名前を表す文字列の配列です。アクセスが必要なオブジェクトストアのみを指定してください。アクセスが必要なオブジェクトストアが 1 個だけである場合は、その名前を文字列で指定できます。そのため、以下の行は等価です。
js
db.transaction(['my-store-name']); db.transaction('my-store-name');データベース内の全てのオブジェクトストアにアクセスする必要がある場合は、
IDBDatabase.objectStoreNamesプロパティを使用できます。js
const transaction = db.transaction(db.objectStoreNames);空の配列を渡すと、例外が投げられます。
mode省略可-
トランザクション内で実行できるアクセスの種類です。トランザクションは
readonly、readwrite、readwriteflush(非標準、Firefox のみ) の 3 種類のいずれかのモードで開始します。versionchangeモードはここでは指定できません。この引数を指定しない場合、デフォルトのアクセスモードはreadonlyです。速度の低下を避けるため、実際にデータベースに書き込む必要がある場合以外はreadwriteトランザクションを開始しないでください。データを更新するためオブジェクトストアを
readwriteモードで開く必要がある場合、以下のようにすると良いです。js
const transaction = db.transaction('my-store-name', "readwrite");Firefox 40 以降、IndexedDB のトランザクションはパフォーマンスを向上させるために永続性を緩めています。(Firefox バグ 1112702 を参照) これは IndexedDB に対応した他のブラウザーと同様の挙動です。以前は、
readwriteトランザクションではcompleteイベントはすべてのデータが確実にディスクに書き込まれてからのみ発火していました。Firefox 40 以降では、completeイベントは OS にデータを書き込む指示を出した後に発火し、データはまだ実際にディスクに書き込まれていない可能性があります。そのため、completeイベントは以前より早く伝わることがありますが、データがディスクに書き込まれる前に OS がクラッシュしたりシステム電源が喪失したりすると、トランザクション全体が失われる可能性が少しあります。そのような最悪の事象はほとんどないため、ほとんどの利用者は気にしなくていいでしょう。メモ: Firefox では、何らかの理由で永続性を保証したい場合 (例えば、後で再計算できない重要なデータを保存する場合)、実験的な (非標準の)
readwriteflushモードを用いてトランザクションを開始することで、completeイベントを伝える前にトランザクションをディスクに書き込むことを強制できます。(IDBDatabase.transactionを参照) これは現在実験的であり、about:configでdom.indexedDB.experimentalをtrueに設定している場合のみ利用できます。 options省略可-
その他のオプションが入った辞書です。以下が利用可能なオプションです。
durability-
"default"、"strict"、"relaxed"のいずれかです。デフォルト値は"default"です。"relaxed"を使用するとパフォーマンスが向上しますが、保証は減ります。ウェブアプリケーションでは、キャッシュや変化が早いレコードなどの一時的なデータには"relaxed"を用い、パフォーマンスや電力に影響してもデータ消失のリスクを減らしたい場合は"strict"を用いるべきです。
返値
IDBTransaction オブジェクトを返します。
例外
InvalidStateErrorDOMException-
この
IDBDatabaseのインスタンスで既にclose()メソッドが呼ばれているとき投げられます。 NotFoundErrorDOMException-
引数
storeNamesで指定されたオブジェクトストアが削除されている、または取り除かれているとき投げられます。 TypeError-
引数
modeの値が無効であるとき投げられます。 InvalidAccessErrorDOMException-
関数がオブジェクトストア名の空のリストとともに呼ばれたとき投げられます。
例
この例では、データベースに接続し、transaction() を用いてデータベース上でトランザクションを開始します。完全な例は To-do Notifications アプリケーションを参照してください。(動く例を見る)
js
let db;
// 我々のデータベースを開きましょう
const DBOpenRequest = window.indexedDB.open("toDoList", 4);
DBOpenRequest.onsuccess = (event) => {
note.innerHTML += '<li>データベースの初期化が完了しました。</li>';
// データベースを開いた結果を変数 db に格納します。
// これはこの先いっぱい使います。
db = DBOpenRequest.result;
// displayData() 関数を呼び出し、IDB に格納済の TO-DO リストの
// データ全てをタスクリストに入れます
displayData();
};
// 読み書き用のデータベーストランザクションを開始し、データを追加する準備をします
const transaction = db.transaction(["toDoList"], "readwrite");
// トランザクション開始が成功したら報告します
transaction.oncomplete = (event) => {
note.innerHTML += '<li>トランザクション完了: データベースの変更が完了しました。</li>';
};
transaction.onerror = (event) => {
note.innerHTML += '<li>エラーによりトランザクションが開始できませんでした。アイテムの重複は禁止です。</li>';
};
// そして、オブジェクトストアを介してデータベースにさらに何かをするでしょう
const objectStore = transaction.objectStore("toDoList");
// など
仕様書
| Specification |
|---|
| Indexed Database API 3.0 # ref-for-dom-idbdatabase-transaction③ |
ブラウザーの互換性
BCD tables only load in the browser
関連情報
- IndexedDB の使用
- トランザクションの開始:
IDBDatabase - トランザクションの使用:
IDBTransaction - キーの範囲の設定:
IDBKeyRange - データの取得と変更:
IDBObjectStore - カーソルの使用:
IDBCursor - リファレンス例: To-do Notifications (動く例を見る)