Opérations de transaction dans ThinkPHP5
Si vous utilisez le traitement des transactions, le moteur de base de données doit prendre en charge le traitement des transactions. Par exemple, MyISAM de MySQL ne prend pas en charge le traitement des transactions et nécessite l'utilisation du moteur InnoDB.
ThinkPHP5.0
Utilisez la méthode de transaction pour exécuter les transactions de base de données Lorsqu'une exception se produit, elle sera automatiquement annulée, par exemple :
.Contrôler automatiquement les transactions La gestion de
Db::transaction(function(){ Db::table('think_user')->find(1); Db::table('think_user')->delete(1);});
peut également contrôler manuellement les transactions, par exemple :
// 启动事务Db::startTrans();try{ Db::table('think_user')->find(1); Db::table('think_user')->delete(1); // 提交事务 Db::commit(); } catch (\Exception $e) { // 回滚事务 Db::rollback();}
ThinkPHP5.1
Le moyen le plus simple est d'utiliser la méthode de transaction pour fonctionner transactions de la base de données. Lorsque le code dans la fermeture Une exception sera automatiquement annulée, par exemple :
Db::transaction(function () { Db::table('think_user')->find(1); Db::table('think_user')->delete(1);});
Vous pouvez également contrôler manuellement la transaction, par exemple :
// 启动事务Db::startTrans();try { Db::table('think_user')->find(1); Db::table('think_user')->delete(1); // 提交事务 Db::commit();} catch (\Exception $e) { // 回滚事务 Db::rollback();}
Notez que lors des opérations de transaction , assurez-vous d'utiliser la même connexion à la base de données.
À partir de la version V5.1.13+, la transaction XA de MySQL peut être prise en charge pour implémenter des transactions globales (distribuées). Vous pouvez utiliser :
Db::transactionXa(function () { Db::connect('db1')->table('think_user')->delete(1); Db::connect('db2')->table('think_user')->delete(1);}, [Db::connect('db1'),Db::connect('db2')]);
Assurez-vous que votre moteur de table de données est InnoDB et activez. Prise en charge des transactions XA.
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!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)