Cet article nécessite une relecture technique. Voici comment vous pouvez aider.
Cet article nécessite une relecture rédactionnelle. Voici comment vous pouvez aider.
La propriété transaction
de l'interface IDBRequest renvoie la transaction
dans laquelle on fait la requête.La propriètè peut renvoiyer null
si requête se fait sans transaction, comme un objet IDBRequest renvoyé par IDBFactory.open
dans ce cas on est juste connecté à la base de données.
Durant la gestion d'un événement upgradeneeded
qui met à jour la version de la base de données, la propriété transaction
doit être une transaction
ouverte en mode
"versionchange"
, on peut alors accéder aux magasins d'objets
et index
ou annulé la mise à niveau. Après quoi, la propriété transaction
renverra encore null
.
Syntaxe
var myTransaction = request.transaction;
Valeur
Une transaction
.
Exemple
L'exemple suivant demande un titre d'enregistrement donné, onsuccess
obtient l'enregistrement associé du magasin d'objects
(mis à disposition en tant que objectStoreTitleRequest.result
), on met à jour une propriété de l'enregistrement, puis le sauve dans le magasin d'objects. La transaction
à l'origine de la deuxième requête
est affichée sur la console du développeur (Ps, les deux requêtes proviennent de la même transaction). En bas est une fonction onerror qui affiche le code d'erreur si la requête échoue. Pour un exemple de travail complet, voir notre To-do Notifications app (view example live).
var title = "Walk dog"; // Ouvrez une transaction comme d'habitude var objectStore = db.transaction(['toDoList'], "readwrite").objectStore('toDoList'); // Obtenez l'objet toDoList qui a ce titre var objectStoreTitleRequest = objectStore.get(title); objectStoreTitleRequest.onsuccess = function() { // Prenez l'objet de données renvoyé comme résultat var data = objectStoreTitleRequest.result; // Mettre à jour la valeur notified de l'objet à "yes" data.notified = "yes"; // Créer une autre requête qui insère le nouvelle élément dans la base de données var updateTitleRequest = objectStore.put(data); // Affiche la transaction à l'origine de la deuxième requête console.log(" la transaction à l'origine de ces requêtes est " + updateTitleRequest.transaction); // Lorsque cette requête réussit, appelle de la fonction displayData() pour mettre à jour l'affichage updateTitleRequest.onsuccess = function() { displayData(); }; objectStoreTitleRequest.onerror = function() { // Si une erreur pendant la requête, on l'affiche console.log("Il y a eu une erreur dans la récupération des données: " + objectStoreTitleRequest.error); };
Cet exemple montre comment la propriété transaction
peut être utilisé pendant une mise à niveau de version pour accéder à des magasins d'objects
existants:
var openRequest = indexedDB.open('db', 2); console.log(openRequest.transaction); // Affiche "null". openRequest.onupgradeneeded = function(event) { console.log(openRequest.transaction.mode); // Affiche "versionchange". var db = openRequest.result; if (event.oldVersion < 1) { // Nouvelle base de données, créer un magasin d'objets "livres". db.createObjectStore('books'); } if (event.oldVersion < 2) { // Mise à niveau de la base de données v1: ajoute un index sur "title" pour stocker les livres. var bookStore = openRequest.transaction.objectStore('books'); bookStore.createIndex('by_title', 'title'); } }; openRequest.onsuccess = function() { console.log(openRequest.transaction); // Affiche "null". };
Spécifications
Spécification | Statut | Commentaire |
---|---|---|
Indexed Database API La définition de 'transaction' dans cette spécification. |
Recommendation |
Compatibilité avec les navigateurs
Fonctionnalité | Chrome | Firefox (Gecko) | Internet Explorer | Opera | Safari (WebKit) |
---|---|---|---|---|---|
Support basique | 23webkit 24 |
10 moz 16.0 (16.0) |
10, en partie | 15 | 7.1 |
Disponible dans workers | (Oui) | 37.0 (37.0) | ? | (Oui) | ? |
Fonctionnalité | Android | Firefox Mobile (Gecko) | Firefox OS | IE Phone | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|
Support basique | 4.4 | 22.0 (22.0) | 1.0.1 | 10 | 22 | 8 |
Disponible dans workers | (Oui) | 37.0 (37.0) | (Oui) | ? | (Oui) | ? |
Voir aussi
- Using IndexedDB
- Starting transactions:
IDBDatabase
- Using transactions:
IDBTransaction
- Setting a range of keys:
IDBKeyRange
- Retrieving and making changes to your data:
IDBObjectStore
- Using cursors:
IDBCursor
- Reference example: To-do Notifications (view example live.)