Maison  >  Article  >  base de données  >  Comment appliquer des déclencheurs et des transactions dans la base de données MySQL

Comment appliquer des déclencheurs et des transactions dans la base de données MySQL

WBOY
WBOYavant
2023-05-28 16:25:191038parcourir

1. Trigger

Concept

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.

2. Opérations de déclenchement

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

Ajouter, supprimer et modifier les opérations des déclencheurs

// 语法格式: 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;

Afficher et supprimer les opérations des déclencheurs

// 查看标准语法: SHOW TRIGGERS;
// 查看触发器
SHOW TRIGGERS;


// 删除标准语法:DROP TRIGGER 触发器名称;
// 删除account_delete触发器
DROP TRIGGER account_delete;

Transactions

Concepts

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.

4. Opération de transaction

Processus de base

  • 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

Opérations de base

-- 开启事务
START TRANSACTION;

-- 执行SQL语句
UPDATE account SET money=money-500 WHERE NAME='张三';

-- 回滚事务(出现问题)
ROLLBACK;

-- 提交事务(没出现问题)
COMMIT;
;

Méthode de soumission des transactions

// 查看提交方式
SELECT @@AUTOCOMMIT;  -- 1代表自动提交    0代表手动提交
// 修改事务的提交方式
SET @@autocommit=1;

Niveau d'isolement des transactions

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 级别字符串;

    Remarque :
  • Le niveau d'isolement devient de plus en plus élevé de petit à grand, mais l'efficacité devient de plus en plus faible , il n'est donc pas recommandé d'utiliser les niveaux d'isolement READ UNCOMMITTED et SERIALIZABLE.

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:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer