Maison > Article > base de données > Comment modifier le niveau d'isolement des transactions dans MySQL
Méthode de modification : 1. Exécutez l'instruction "set session transaction isolation level transaction level ;" dans la fenêtre de commande ; 2. Ouvrez le fichier "mysql.ini" et ajoutez l'instruction "transaction-isolation=transaction level".
L'environnement d'exploitation de ce tutoriel : système windows7, version mysql8, ordinateur Dell G3.
niveau d'isolement des transactions mysql
Le niveau d'isolement d'une transaction est divisé en : lecture non validée (lecture non validée), lecture validée (lecture validée), lecture répétable (lecture répétable), sérialisable (sérialisable).
Lire non validé (lire le contenu non validé)
À ce niveau d'isolement, toutes les transactions peuvent voir les résultats d'exécution d'autres transactions non validées. Ce niveau d'isolation est rarement utilisé dans les applications pratiques car ses performances ne sont guère meilleures que les autres niveaux. La lecture de données non validées est également appelée lecture sale.
Read Comended (lire le contenu du commit)
Il s'agit du niveau d'isolement par défaut de la plupart des systèmes de bases de données (mais pas celui par défaut de MySQL). Cela répond à la définition simple de l'isolement : une transaction ne peut voir que les modifications apportées par les transactions validées. Ce niveau d'isolement prend également en charge ce que l'on appelle la lecture non répétable, car d'autres instances de la même transaction peuvent avoir de nouvelles validations pendant le traitement de l'instance, de sorte que la même sélection peut renvoyer des résultats différents.
Lecture répétable (répétable)
Il s'agit du niveau d'isolation des transactions par défaut de MySQL. Il garantit que plusieurs instances de la même transaction verront les mêmes lignes de données lors de la lecture simultanée des données. Mais en théorie, cela entraînerait un autre problème épineux : la lecture fantôme. En termes simples, la lecture fantôme signifie que lorsque l'utilisateur lit une certaine plage de lignes de données, une autre transaction insère une nouvelle ligne dans la plage. Lorsque l'utilisateur lit les lignes de données dans la plage, il constatera qu'il y a de nouveaux " Fantôme " OK. . Les moteurs de stockage InnoDB et Falcon résolvent ce problème grâce au mécanisme MVCC (Multiversion Concurrency Control).
Sérialisable
Il s'agit du niveau d'isolement le plus élevé. Il résout le problème de lecture fantôme en forçant les transactions à être ordonnées afin qu'elles ne puissent pas entrer en conflit les unes avec les autres. En bref, il ajoute un verrou partagé sur chaque ligne de données lue. À ce niveau, de nombreux délais d'attente et conflits de verrouillage peuvent en résulter.
mysql Modifier le niveau d'isolement des transactions
Méthode 1 : exécuter la modification de la commande
//查看当前事物级别: SELECT @@tx_isolation;
//设置mysql的隔离级别: set session transaction isolation level 需要设置的事务隔离级别
Exemple
//设置read uncommitted级别: set session transaction isolation level read uncommitted; //设置read committed级别: set session transaction isolation level read committed; //设置repeatable read级别: set session transaction isolation level repeatable read; //设置serializable级别: set session transaction isolation level serializable;
Méthode 2 : modification de la configuration mysql.ini
Ouvrez mysql. ini, ajoutez
#可选参数有:READ-UNCOMMITTED, READ-COMMITTED, REPEATABLE-READ, SERIALIZABLE. [mysqld] transaction-isolation = REPEATABLE-READ
La valeur par défaut globale ici est REPEATABLE-READ En fait, MySQL par défaut est ce niveau
[Recommandations associées : Tutoriel vidéo mysql]
.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!