Maison >base de données >tutoriel mysql >Comment appliquer des déclencheurs et des transactions dans la base de données MySQL
Trigger est une méthode fournie par le serveur SQL aux programmeurs et aux analystes de données pour garantir l'intégrité des données. Il s'agit d'une procédure stockée spéciale liée aux événements de table et déclenchée par des événements. Les déclencheurs sont souvent utilisés pour appliquer des contraintes d’intégrité des données et des règles métier.
Créer des tables de données de compte et de journal de compte :
CREATE TABLE account( id INT PRIMARY KEY AUTO_INCREMENT, NAME VARCHAR(20), money DOUBL ); INSERT INTO account VALUES (NULL,'张三',1000),(NULL,'李四',1000); CREATE TABLE account_log( id INT PRIMARY KEY AUTO_INCREMENT, operation VARCHAR(20), operation_time DATETIME, operation_id INT, operation_params VARCHAR(200) );
// 语法格式: BEFORE|AFTER INSERT: 插入 UPDATE:更新 DELETE:删除 // DELIMITER $ // CREATE TRIGGER 触发器名称 // BEFORE|AFTER INSERT|UPDATE|DELETE // ON 表名 // FOR EACH ROW // BEGIN // 触发器要执行的功能; // END$ // DELIMITER ; // 创建INSERT型触发器。用于对account表新增数据进行日志的记录 DELIMITER $ CREATE TRIGGER account_insert AFTER INSERT ON account FOR EACH ROW BEGIN INSERT INTO account_log VALUES (NULL,'INSERT',NOW(),new.id,CONCAT('插入后{id=',new.id,',name=',new.name,',money=',new.money,'}')); END $ DELIMITER ; // 向account表添加一条记录 INSERT INTO account VALUES (NULL, '王五', 2000); // 查询account表 SELECT * FROM account;
// 查看标准语法: SHOW TRIGGERS; // 查看触发器 SHOW TRIGGERS; // 删除标准语法:DROP TRIGGER 触发器名称; // 删除account_delete触发器 DROP TRIGGER account_delete;
Dans. relations Dans une base de données, une transaction peut être une instruction SQL, un ensemble d'instructions SQL ou un programme entier. Sa caractéristique est que cette unité réussit ou échoue en même temps, et chaque instruction SQL de l'unité dépend les unes des autres pour former un tout. Les transactions doivent avoir quatre attributs : atomicité, cohérence, isolation et durabilité. Ces quatre propriétés sont souvent appelées Propriétés ACIDES.
Quatre fonctionnalités majeures :
Atomicité : Une transaction est une unité de travail indivisible. Toutes les opérations incluses dans la transaction réussiront ou seront annulées si elles échouent.
Cohérence : Les transactions doivent faire passer la base de données d'un état de cohérence à un autre état de cohérence, c'est-à-dire qu'une transaction doit être dans un état cohérent avant et après son exécution.
Isolement : Lorsque plusieurs utilisateurs accèdent simultanément à la base de données, par exemple lors de l'utilisation de la même table, les transactions ouvertes par la base de données pour chaque utilisateur ne peuvent pas être interférées par les opérations d'autres transactions. Plusieurs transactions simultanées doivent être séparées mutuellement. isolement
Persistance : Une fois qu'une transaction est soumise, les modifications apportées aux données dans la base de données sont permanentes Même si le système de base de données rencontre une panne, l'opération de soumission de la transaction ne sera pas perdue.
Démarrer une transaction : Enregistrer le point de restauration et avertir le serveur
Exécuter une instruction SQL : Exécuter une ou plusieurs instructions SQL spécifiques
Fin de transaction (soumettre|rollback) : Soumettre : Aucun problème ne se produit, les données sont mises à jour Rollback : Un problème se produit, les données sont restaurées à l'état où la transaction a été démarrée
-- 开启事务 START TRANSACTION; -- 执行SQL语句 UPDATE account SET money=money-500 WHERE NAME='张三'; -- 回滚事务(出现问题) ROLLBACK; -- 提交事务(没出现问题) COMMIT;;
// 查看提交方式 SELECT @@AUTOCOMMIT; -- 1代表自动提交 0代表手动提交 // 修改事务的提交方式 SET @@autocommit=1;
Quatre niveaux d'isolement
Lecture non validée : lecture non validée
Lecture validée : lecture validée (niveau par défaut de la base de données Oracle/SQL Server)
Lecture répétable : lecture répétable (niveau par défaut de MySQL)
Lecture sale : signifie Données dans un autre non validé la transaction a été lue au cours d'une transaction , entraînant des résultats de requête incohérents entre les deux
Lecture non répétable : fait référence à la lecture des données d'une autre transaction au cours d'une transaction. Les données modifiées et soumises ont entraîné des résultats de requête incohérents entre les deux requêtes
. Lecture fantôme : sélectionnez si un certain enregistrement existe. Il n'existe pas. Je me préparais à insérer cet enregistrement, mais lors de l'exécution de l'insertion, j'ai constaté que cet enregistrement existe déjà et ne peut pas être inséré. Ou la suppression par suppression n'existe pas, mais la suppression s'avère réussie
Opération d'isolement// 查询数据库隔离级别
SELECT @@TX_ISOLATION;
// 修改数据库隔离级别
SET GLOBAL TRANSACTION ISOLATION LEVEL 级别字符串;
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!