mysqli->autocommit( false) ;" méthode pour désactiver la soumission automatique."/> mysqli->autocommit( false) ;" méthode pour désactiver la soumission automatique.">

Maison  >  Article  >  développement back-end  >  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 ?

藏色散人
藏色散人original
2022-10-20 09:49:131204parcourir

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

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;
    }
}

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;
}

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;

Problème résolu :

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

$this->mysqli->autocommit(false);

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!

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