IDBRequest.transaction

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.

Note : This feature is available in Web Workers.

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

Étiquettes et contributeurs liés au document

 Contributeurs à cette page : gadgino
 Dernière mise à jour par : gadgino,