Manuel PHP

mysqli::rollback

mysqli_rollback

(PHP 5)

mysqli::rollback -- mysqli_rollbackAnnule la transaction courante

Description

Style orienté objet :

bool mysqli::rollback ( void )

Style procédural :

bool mysqli_rollback ( mysqli $link )

Annule la transaction courante pour la base de données.

Liste de paramètres

link

Style procédural uniquement : Un identifiant de lien retourné par la fonction mysqli_connect() ou par la fonction mysqli_init()

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. $mysqli = new mysqli("localhost", "my_user", "my_password", "world");  
  3.  
  4. /* Vérification de la connexion */  
  5. if (mysqli_connect_errno()) { 
  6.    printf("Échec de la connexion : %s\n", mysqli_connect_error()); 
  7.    exit();  
  8. }  
  9.  
  10. /* Désactive l'auto-commit */  
  11. $mysqli->autocommit(FALSE);  
  12.  
  13. $mysqli->query("CREATE TABLE myCity LIKE City");  
  14. $mysqli->query("ALTER TABLE myCity Type=InnoDB");  
  15. $mysqli->query("INSERT INTO myCity SELECT * FROM City LIMIT 50");  
  16.  
  17. /* Validation */  
  18. $mysqli->commit();  
  19.  
  20. /* Effacement de toutes les lignes */  
  21. $mysqli->query("DELETE FROM myCity");  
  22.  
  23. if ($result = $mysqli->query("SELECT COUNT(*) FROM myCity")) { 
  24.    $row = $result->fetch_row(); 
  25.    printf("%d ligne dans la table myCity.\n", $row[0]); 
  26.    /* Free result */ 
  27.    $result->close();  
  28. }  
  29.  
  30. /* Rollback */  
  31. $mysqli->rollback();  
  32.  
  33. if ($result = $mysqli->query("SELECT COUNT(*) FROM myCity")) { 
  34.    $row = $result->fetch_row(); 
  35.    printf("%d lignes dans la table myCity (après annulation).\n", $row[0]); 
  36.    /* Libère le résultat */ 
  37.    $result->close();  
  38. }  
  39.  
  40. /* Effacement de la table myCity */  
  41. $mysqli->query("DROP TABLE myCity");  
  42.  
  43. $mysqli->close();  
  44. ?> 

Exemple #2 Style procédural

  1. <?php
  2. $link = mysqli_connect("localhost", "my_user", "my_password", "world");  
  3.  
  4. /* Vérification de la connexion */  
  5. if (mysqli_connect_errno()) { 
  6.    printf("Échec de la connexion : %s\n", mysqli_connect_error()); 
  7.    exit();  
  8. }  
  9.  
  10. /* Désactive l'auto-commit */  
  11. mysqli_autocommit($link, FALSE);  
  12.  
  13. mysqli_query($link, "CREATE TABLE myCity LIKE City");  
  14. mysqli_query($link, "ALTER TABLE myCity Type=InnoDB");  
  15. mysqli_query($link, "INSERT INTO myCity SELECT * FROM City LIMIT 50");  
  16.  
  17. /* Validation */  
  18. mysqli_commit($link);  
  19.  
  20. /* Effacement de toutes les lignes */  
  21. mysqli_query($link, "DELETE FROM myCity");  
  22.  
  23. if ($result = mysqli_query($link, "SELECT COUNT(*) FROM myCity")) { 
  24.    $row = mysqli_fetch_row($result); 
  25.    printf("%d ligne dans la table myCity.\n", $row[0]); 
  26.    /* Libère le résultat */ 
  27.    mysqli_free_result($result);  
  28. }  
  29.  
  30. /* Rollback */  
  31. mysqli_rollback($link);  
  32.  
  33. if ($result = mysqli_query($link, "SELECT COUNT(*) FROM myCity")) { 
  34.    $row = mysqli_fetch_row($result); 
  35.    printf("%d lignes dans la table myCity (après annulation).\n", $row[0]); 
  36.    /* Free result */ 
  37.    mysqli_free_result($result);  
  38. }  
  39.  
  40. /* Effacement de la table myCity */  
  41. mysqli_query($link, "DROP TABLE myCity");  
  42.  
  43. mysqli_close($link);  
  44. ?> 

L'exemple ci-dessus va afficher :

0 ligne dans la table myCity. 50 lignes dans la table myCity (après annulation).

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