Manuel PHP

maxdb_rollback

maxdb->rollback

(PECL maxdb >= 1.0)

maxdb_rollback -- maxdb->rollbackAnnule la transaction courante

Description

bool maxdb_rollback ( resource $link )
maxdb
bool rollback ( void )

Annule la transaction courante pour la base de données spécifiée par le paramètre link .

Valeurs de retour

Cette fonction retourne TRUE en cas de succès, FALSE en cas d'échec.

Exemples

Exemple #1 Style orienté objet

  1. <?php
  2. $maxdb = new maxdb("localhost", "MONA", "RED", "DEMODB");  
  3.  
  4. /* Vérification de la connexion */  
  5. if (maxdb_connect_errno()) { 
  6.    printf("Echec de la connexion : %s\n", maxdb_connect_error()); 
  7.    exit();  
  8. }  
  9.  
  10. /* Désactive l'auto-commit */  
  11. $maxdb->autocommit(FALSE);  
  12.  
  13. $maxdb->query("CREATE TABLE temp.mycity LIKE hotel.city");  
  14. $maxdb->query("INSERT INTO temp.mycity SELECT * FROM hotel.city");  
  15.  
  16. /* Exécution */  
  17. $maxdb->commit();  
  18.  
  19. /* Efface toutes les lignes */  
  20. $maxdb->query("DELETE FROM temp.mycity");  
  21.  
  22. if ($result = $maxdb->query("SELECT COUNT(*) FROM temp.mycity")) { 
  23.    $row = $result->fetch_row(); 
  24.    printf("%d rows in table mycity.\n", $row[0]); 
  25.    /* Free result */ 
  26.    $result->close();  
  27. }  
  28.  
  29. /* Rollback */  
  30. $maxdb->rollback();  
  31.  
  32. if ($result = $maxdb->query("SELECT COUNT(*) FROM temp.mycity")) { 
  33.    $row = $result->fetch_row(); 
  34.    printf("%d ligne dans la table mycity (après annulation).\n", $row[0]); 
  35.    /* Libération du résultat */ 
  36.    $result->close();  
  37. }  
  38.  
  39. /* Effacement de la table myCity */  
  40. $maxdb->query("DROP TABLE temp.mycity");  
  41.  
  42. $maxdb->close();  
  43. ?> 

Exemple #2 Style procédural

  1. <?php
  2. $link = maxdb_connect("localhost", "MONA", "RED", "DEMODB");  
  3.  
  4. /* Vérification de la connexion */  
  5. if (maxdb_connect_errno()) { 
  6.    printf("Echec de la connexion : %s\n", maxdb_connect_error()); 
  7.    exit();  
  8. }  
  9.  
  10. /* Désactive l'auto-commit */  
  11. maxdb_autocommit($link, FALSE);  
  12.  
  13. maxdb_query($link, "CREATE TABLE temp.mycity LIKE hotel.city");  
  14. maxdb_query($link, "INSERT INTO temp.mycity SELECT * FROM hotel.city");  
  15.  
  16. /* Exécution */  
  17. maxdb_commit($link);  
  18.  
  19. /* Efface toutes les lignes */  
  20. maxdb_query($link, "DELETE FROM temp.mycity");  
  21.  
  22. if ($result = maxdb_query($link, "SELECT COUNT(*) FROM temp.mycity")) { 
  23.    $row = maxdb_fetch_row($result); 
  24.    printf("%d ligne dans la table mycity.\n", $row[0]); 
  25.    /* Libération du résultats */ 
  26.    maxdb_free_result($result);  
  27. }  
  28.  
  29. /* Annulation */  
  30. maxdb_rollback($link);  
  31.  
  32. if ($result = maxdb_query($link, "SELECT COUNT(*) FROM temp.mycity")) { 
  33.    $row = maxdb_fetch_row($result); 
  34.    printf("%d lignes dans la table mycity (après annulation).\n", $row[0]); 
  35.    /* Libération du résultat */ 
  36.    maxdb_free_result($result);  
  37. }  
  38.  
  39. /* Effacement de la table myCity */  
  40. maxdb_query($link, "DROP TABLE temp.mycity");  
  41.  
  42. maxdb_close($link);  
  43. ?> 

L'exemple ci-dessus va afficher quelque chose de similaire à :

0 ligne dans la table mycity. 25 lignes dans la table mycity (après annulation).

Remonter Remonter
L'éditeur javascript - CSS - Gentoo - Tutoriaux PHP - Tutoriels PHP - Bretagne - php - Moto - Kit graphique