Maison >développement back-end >Problème PHP >Comment utiliser correctement PDO ::beginTransaction en PHP

Comment utiliser correctement PDO ::beginTransaction en PHP

autoload
autoloadoriginal
2021-04-26 09:52:131736parcourir

Les transactions sont une opération courante dans SQL. Dans les opérations quotidiennes, nous devons souvent ajouter, supprimer et modifier la base de données. Des problèmes surviendront inévitablement lors de l'exploitation des données, afin d'éviter de telles erreurs majeures. la fonction PHP Cet article vous amène à y jeter un oeil. beginTransaction

Tout d'abord, jetons un coup d'œil à la syntaxe de la fonction

 : beginTransaction()

beginTransaction (   )

  • Désactivez le mode de validation automatique. Lorsque le mode de validation automatique est désactivé, les modifications apportées à la base de données via l'instance d'objet

    ne sont pas validées tant que PDO n'est pas appelé pour mettre fin à la transaction. L'appel de PDO::commit() annulera les modifications apportées à la base de données et ramènera la connexion à la base de données en mode de validation automatique. PDO::rollBack()

  • Valeur de retour : renvoie

    en cas de succès ou true en cas d'échec. false

Exemple de code :

1. Partie connexion à la base de données :


<?php
$servername = "localhost";
$username = "root";
$password = "root123456";
$dbname   = "my_database";
 
try {
    $pdo = new PDO("mysql:host=$servername;dbname=$dbname", $username, $password);
    echo "连接成功"."<br>"; 
    $pdo->setAttribute(PDO::ATTR_CASE, PDO::CASE_UPPER);
    }
catch(PDOException $e)
{
    $pdo->rollBack();
    echo $e->getMessage();
}
?>

2. Transaction ouverte :

    $pdo->beginTransaction();
/* 在全有或全无的基础上插入多行记录(要么全部插入,要么全部不插入) */
    $sql = "INSERT INTO fate (id, name, age)VALUES (10,&#39;王五&#39;,27)";
    $sth = $pdo->exec($sql);

/* 提交更改 */
$pdo->commit();
/* 现在数据库连接返回到自动提交模式 */

Recommandé : "Résumé des questions d'entretien PHP 2021 (collection) " "Tutoriel vidéo PHP

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn