Maison > développement back-end > Problème PHP > Que dois-je faire si la transaction php ne peut pas être annulée ?

Que dois-je faire si la transaction php ne peut pas être annulée ?

藏色散人
Libérer: 2023-03-17 07:18:01
original
1294 Les gens l'ont consulté

Solution à la transaction PHP qui ne peut pas être annulée : 1. Ouvrez le fichier PHP correspondant ; 2. Vérifiez le code "function update_user_set_date_of_birth($date_of_birth){...}" 3. Passez "$this->mysqli- ; > Autocommit(false);" peut être utilisé pour désactiver la soumission automatique.

Que dois-je faire si la transaction php ne peut pas être annulée ?

L'environnement d'exploitation de ce tutoriel : système Windows 7, PHP version 8.1, ordinateur Dell G3.

Que dois-je faire si la transaction PHP ne peut pas être annulée ?

Description du problème :

À propos de la transaction PHP qui n'effectue pas de restauration

mysqliphptransactions
Transactions not doing the rollback
Copier après la connexion

J'ai la fonction de mettre à jour l'utilisateur :

function update_user_set_common($date_of_birth, $mobile, $street, $housenumber, $addition, $postal_code, $location, $country)
{
    try {
        $this->mysqli->begin_transaction();
        $this->update_user_set_date_of_birth($date_of_birth);
        $this->update_user_set_mobile($mobile);
        $this->update_user_set_address($street, $housenumber, $addition, $postal_code, $location, $country);
        $this->mysqli->commit();
        return true;
    } catch (Exception $e) {
        $this->mysqli->rollback();
        echo"Error:" . $e;
        return false;
    }
}
Copier après la connexion

Comme vous pouvez le voir, j'ai effectué une transaction. Si tout va bien, il doit être validé, si une erreur se produit, il doit être annulé.

Voici un exemple du fonctionnement de ma requête de mise à jour :

function update_user_set_date_of_birth($date_of_birth)
{
    return $this->update_user_set_singlefield(COL_USER_DATE_OF_BIRTH, $date_of_birth);
}
function update_user_set_singlefield($field, $value)
{
    if ($update_stmt = $this->mysqli->prepare("UPDATE" . TABLE_USER ." SET" . $field ." = ? WHERE" . COL_USER_ID ." = ?")) :
        if (!$update_stmt->bind_param("ss", $value, $this->USER_ID)) :
            $update_stmt->close();
            return false;
        endif;
        if (!$update_stmt->execute()) :
            $update_stmt->close();
            return false;
        else :
            $update_stmt->close();
            return true;
        endif;
    else :
        return false;
    endif;
}
Copier après la connexion

Alors maintenant, par exemple, update_user_set_mobile échoue, mais il n'y a pas de restauration. L'instruction avant update_user_set_date_of_birth sera toujours exécutée et ne reviendra pas à l'originale.

Pourquoi n’y a-t-il pas de restauration ?

Exemple de création de table à me montrer en utilisant innodb :

CREATE TABLE `USER` (
  `USER_ID` bigint(20) NOT NULL PRIMARY KEY AUTO_INCREMENT,
  `USER_E_MAIL` varchar(255) COLLATE utf8_bin NOT NULL,
  `USER_PASSWORT` varchar(255) COLLATE utf8_bin NOT NULL,
  `USER_PASSWORT_SALT` varchar(255) COLLATE utf8_bin NOT NULL,
  `USER_FIRSTNAME` varchar(255) COLLATE utf8_bin NOT NULL,
  `USER_LASTNAME` varchar(255) COLLATE utf8_bin NOT NULL,
  `USER_DATE_OF_BIRTH` varchar(200) COLLATE utf8_bin DEFAULT NULL,
  `USER_MOBILE` varchar(255) COLLATE utf8_bin DEFAULT NULL,
  `ADDRESS_ID` bigint(20) DEFAULT NULL
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin;
Copier après la connexion

Problème résolu :

Désactivez la validation automatique au lieu de mysqli->begin_transaction();

$this->mysqli->autocommit(false);
Copier après la connexion

http://php.net/manual/zh/mysqli .autocommit.php

Apprentissage recommandé : "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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
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
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal