Maison base de données tutoriel mysql Une brève discussion sur l'isolation des transactions MySQL

Une brève discussion sur l'isolation des transactions MySQL

Apr 04, 2020 am 09:29 AM
mysql Isolement des transactions

Cet article parle de l'isolation des transactions MySQL. Il a une certaine valeur de référence. Les amis dans le besoin peuvent s'y référer. J'espère qu'il sera utile à tout le monde.

Une brève discussion sur l'isolation des transactions MySQL

Introduction aux transactions

Une transaction est un ensemble de requêtes SQL atomiques, ou un travail indépendant unité. En bref, les instructions au sein d’une transaction s’exécutent toutes avec succès ou échouent toutes.

Dans Mysql, la prise en charge des transactions est implémentée au niveau de la couche moteur, mais tous les moteurs Mysql ne prennent pas en charge les transactions. Par exemple, le moteur MyISAM ne prend pas en charge les transactions. C'est l'une des raisons importantes pour lesquelles MyISAM a été remplacé par InnoDB. .

En matière de transactions, on pensera certainement à ACID :

  • Atomicité

  • Cohérence

  • Isolement

  • Durabilité

Niveau d'isolement

Lorsque plusieurs transactions sont exécutées simultanément dans la base de données, des problèmes tels que des lectures sales, des lectures non répétables et des lectures fantômes peuvent survenir en raison du concept de niveau d'isolation des transactions.

Le standard SQL définit quatre niveaux d'isolement :

  1. READ UNCOMMITTED (lecture non validée)

    Modifications dans la transaction, même si elles n'ont pas encore été commités , sont visibles par les autres transactions. Les transactions peuvent lire des données non validées, également appelées lecture sale.

  2. LECTURE COMMITTED

    Une fois qu'une transaction est validée, les modifications peuvent être vues par d'autres transactions. Ce niveau est également appelé lecture non répétable, car si la même requête est exécutée deux fois dans une transaction, les résultats peuvent être différents.

  3. REPEATABLE READ (lecture répétable)

    Lors de l'exécution d'une transaction, les données vues au démarrage de la transaction sont toujours cohérentes. Bien entendu, à ce niveau, les modifications de données non validées sont également invisibles pour les autres transactions.

  4. SERIALIZABLE (sérialisable)

    Pour la même ligne d'enregistrements, l'écriture et la lecture seront verrouillées. Lorsqu'un conflit de verrouillage en lecture-écriture se produit, la transaction est accessible ultérieurement. doit Attendre la fin de la transaction précédente avant de continuer entraînera de nombreux problèmes de délai d'attente et de conflit de verrouillage.

En termes de mise en œuvre, une vue sera créée dans la base de données, et la logique de la vue prévaudra lors de l'accès.

Sous le niveau d'isolement de lecture répétable, cette vue est créée au démarrage de la transaction, et cette vue est utilisée pendant toute la transaction.

Sous le niveau d'isolement lecture-validation, cette vue est créée lorsque l'instruction SQL commence à s'exécuter.

Sous le niveau d'isolement de lecture non validée, la dernière valeur de l'enregistrement est renvoyée directement, sans le concept de vue.

Sous le niveau d'isolement sérialisé, verrouillez directement pour éviter l'accès parallèle.

est configuré en réglant le paramètre de démarrage transaction-isolation au niveau d'isolement souhaité.

Affichez les paramètres actuels :

mysql> show variables like 'transaction_isolation';
+-----------------------+-----------------+
| Variable_name         | Value           |
+-----------------------+-----------------+
| transaction_isolation | REPEATABLE-READ |
+-----------------------+-----------------+
1 row in set (0.00 sec)

En bref, c'est raisonnable s'il existe. Différents niveaux d'isolement conviennent à différents scénarios. Nous devons décider en fonction du scénario commercial.

Mise en œuvre de l'isolement des transactions

Dans Mysql, en fait, la mise à jour de chaque enregistrement enregistrera également une opération de rollback via l'opération de rollback. , la dernière valeur de l'état précédent peut être obtenue.

Le système déterminera automatiquement que lorsqu'aucune transaction ne doit être annulée, le journal d'annulation sera supprimé.

Pourquoi il n'est pas recommandé d'utiliser des transactions longues :

Les transactions longues signifient qu'il y aura de très anciennes vues de transactions dans le système puisque ces transactions peuvent accéder à n'importe quelle donnée de la base de données à tout moment. , avant de soumettre cette transaction, les enregistrements d'annulation pouvant être utilisés dans la base de données doivent être conservés, ce qui prendra beaucoup d'espace de stockage. Dans le même temps, les transactions longues occupent également des ressources de verrouillage et peuvent faire tomber la bibliothèque entière.

Comment démarrer la transaction

  • Démarrer explicitement la déclaration de transaction, commencer ou démarrer la transaction, valider signifie valider, return Utiliser la restauration.

  • set autocommit = 0, cette commande désactivera la soumission automatique du fil, ce qui signifie que si vous exécutez une instruction select, la transaction sera démarrée et ne sera pas automatiquement validée jusqu'à ce que vous exécutiez activement la validation ou la restauration, ou que vous vous déconnectiez.

Ma suggestion personnelle est de démarrer explicitement la transaction via la première méthode pour éviter l'apparition de transactions longues.

Dans le cas de set autocommit = 1, une transaction démarrée explicitement avec start sera validée si commit est exécuté. Si vous exécutez un travail et une chaîne de validation, la transaction est validée et la transaction suivante est automatiquement démarrée, ce qui évite également la surcharge liée à l'exécution à nouveau de l'instruction de début.

Interroger les transactions longues :

L'instruction suivante consiste à interroger les transactions d'une durée supérieure à 60 s

mysql> select * from information_schema.innodb_trx where TIME_TO_SEC(timediff(now(),trx_started))>60;
Empty set (0.00 sec)

Pour résumer, pendant le processus de développement, nous essayez d'en faire le moins possible. Utilisez des transactions longues. Si cela ne peut être évité, assurez-vous que l'espace de journalisation logique est suffisamment grand et prend en charge la croissance dynamique de l'espace de journalisation. Surveillez la table Innodb_trx et signalez une alarme de transaction longue.

Recommandé : "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!

Déclaration de ce site Web
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

Outils d'IA chauds

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

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 !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Sujets chauds

Tutoriel PHP
1535
276
Meilleures pratiques pour gérer les grandes tables MySQL Meilleures pratiques pour gérer les grandes tables MySQL Aug 05, 2025 am 03:55 AM

Lorsque vous traitez avec de grandes tables, les performances MySQL et la maintenabilité sont confrontées à des défis, et il est nécessaire de commencer à partir de la conception structurelle, de l'optimisation des index, de la stratégie de sous-table de tableau, etc. 1. Concevoir raisonnablement les clés et les index primaires: il est recommandé d'utiliser des entiers auto-incrémentés comme clés principales pour réduire les scintillement de pages; Utiliser les index de superposition pour améliorer l'efficacité de la requête; Analyser régulièrement les journaux de requête lents et supprimer les index non valides. 2. Utilisation rationnelle des tables de partition: partition en fonction de la plage de temps et d'autres stratégies pour améliorer l'efficacité de la requête et de la maintenance, mais l'attention devrait être accordée aux problèmes de partitionnement et de coupe. 3. Envisagez de lire et d'écrire la séparation et la séparation des bibliothèques: la séparation de lecture et d'écriture atténue la pression sur la bibliothèque principale. La séparation de la bibliothèque et la séparation des tableaux conviennent aux scénarios avec une grande quantité de données. Il est recommandé d'utiliser des middleware et d'évaluer les problèmes de requête des transactions et des magasins croisés. La planification précoce et l'optimisation continue sont la clé.

Comment utiliser les contraintes de vérification pour appliquer les règles de données dans MySQL? Comment utiliser les contraintes de vérification pour appliquer les règles de données dans MySQL? Aug 06, 2025 pm 04:49 PM

MySQL prend en charge les contraintes de contrôle pour forcer l'intégrité du domaine, efficace à partir de la version 8.0.16; 1. Ajoutez des contraintes lors de la création d'un tableau: utilisez crééTable pour définir les conditions de contrôle, telles que l'âge ≥ 18, salaire> 0, valeurs limites du département; 2. Modifiez le tableau pour ajouter des contraintes: utilisez alterTableAddConstraint pour limiter les valeurs de champ, telles que le nom non vide; 3. Utiliser des conditions complexes: Prise en charge la logique et les expressions multi-colonnes, telles que la date de fin ≥ Date et l'état d'achèvement doivent avoir une date de fin; 4. Supprimer les contraintes: utilisez alterTabledRopConstraint pour spécifier le nom à supprimer; 5. Remarques: MySQL8.0.16, Innodb ou Myisam doit être cité

Comment implémenter un système de balise dans une base de données MySQL? Comment implémenter un système de balise dans une base de données MySQL? Aug 05, 2025 am 05:41 AM

Useamany-to-gyrelateeshipswithajunctiontabletolinkitemsandtagsviathreetables: éléments, tags, anditem_tags.2.whenaddingtags, checkforexistingtagsinthetagstable, insertifnecessary, thencreatemappingsinitem_tagsusingtransactionsforcencence..

Comment dépanner les erreurs de connexion MySQL courantes? Comment dépanner les erreurs de connexion MySQL courantes? Aug 08, 2025 am 06:44 AM

Vérifiez si le service MySQL est en cours d'exécution, utilisez SudosystemctlStatusMysQL pour confirmer et démarrer; 2. Assurez-vous que Bind-Address est défini sur 0,0.0.0 pour permettre les connexions distantes et redémarrer le service; 3. Vérifiez si le port 3306 est ouvert, vérifiez et configurez les règles de pare-feu pour permettre le port; 4. Pour l'erreur "AccessEnedy", vous devez vérifier le nom d'utilisateur, le mot de passe et le nom d'hôte, puis vous connecter à MySQL et interroger la table MySQL.User pour confirmer les autorisations. Si nécessaire, créez ou mettez à jour l'utilisateur et autorisez-le, comme l'utilisation de «votre_user» @ «%»; 5. Si l'authentification est perdue à cause de Caching_Sha2_Password

Implémentation du suivi de la lignée des données MySQL Implémentation du suivi de la lignée des données MySQL Aug 02, 2025 pm 12:37 PM

Les méthodes de base pour réaliser le suivi des liens sanguins de données MySQL incluent: 1. Utilisez le binlog pour enregistrer la source de changement de données, activer et analyser le binlog et tracer des actions commerciales spécifiques en combinaison avec le contexte de la couche d'application; 2. Injecter les liens de sang dans le processus ETL et enregistrer la relation de mappage entre la source et la cible lors de la synchronisation de l'outil; 3. Ajouter des commentaires et des balises de métadonnées aux données, expliquez la source de champ lors de la construction du tableau et connectez-vous au système de gestion des métadonnées pour former une carte visuelle; 4. Faites attention à la cohérence de la clé primaire, évitez une dépendance excessive à l'égard de l'analyse SQL, des changements de modèle de données de contrôle de version et vérifiez régulièrement les données de liens sanguins pour assurer le suivi précis et fiable des liens de sang.

Quelle est la différence entre tronquer, supprimer et tomber dans MySQL? Quelle est la différence entre tronquer, supprimer et tomber dans MySQL? Aug 05, 2025 am 09:39 AM

DeleterMovesspecificorAllRows, KeepSableStructure, permet de faire des effectifs et de surgurer de manière

Comment mettre à niveau un serveur MySQL vers une version plus récente? Comment mettre à niveau un serveur MySQL vers une version plus récente? Aug 03, 2025 am 09:04 AM

CheckCompatibilitéwithos, Applications et Features; 2.BackupallData, Configs, andlogs; 3.ChooseupgradeMethod (PackageManager, MySQLinstaller, Ormanual); 4.Runpost-upgradeCkEckSandtests; 5.ResolvessueslikEuthenticationpluginsordepreatedOptions.

Comment afficher toutes les bases de données dans MySQL Comment afficher toutes les bases de données dans MySQL Aug 08, 2025 am 09:50 AM

Pour afficher toutes les bases de données dans MySQL, vous devez utiliser la commande showDatabases; 1. Après être connecté au serveur MySQL, vous pouvez exécuter les showDatabases; Commande pour répertorier toutes les bases de données auxquelles l'utilisateur actuel a la permission d'accéder; 2. 3. Vous pouvez également interroger et filtrer la base de données via selectSchema_namefrominformation_schema.schemata; Par exemple, l'exclusion de la base de données système pour afficher uniquement la base de données créée par les utilisateurs; Assurez-vous d'utiliser

See all articles