recherche
Maisonbase de donnéestutoriel mysqlBase de données - Une brève discussion sur quatre niveaux d'isolement des transactions

La base de données fournit quatre niveaux d'isolement des transactions. Différents niveaux d'isolement sont implémentés en utilisant différentes classes de verrouillage

Parmi les quatre niveaux d'isolement, Serialisable est le niveau le plus élevé et Read Uncommited est le plus bas. 🎜>Le niveau d'isolement par défaut de la plupart des bases de données est : Lecture validée, comme Sql Server, Oracle
Le niveau d'isolement par défaut de quelques bases de données est Lecture répétable, comme
MySQL Moteur de stockage InnoDB Même il s'agit du niveau le plus bas, et le premier type de problème de mise à jour perdue ne se produira pas 1 Lecture sale (la transaction n'est pas validée, lue à l'avance) : une lecture sale signifie qu'une transaction accède aux données et au niveau le plus bas. les données sont modifiées et cette modification n'a pas encore été soumise à la base de données. À ce moment, une autre transaction accède également à ces données et utilise ensuite ces données.
2. Lecture non répétable (incohérence entre deux lectures) : fait référence à la lecture plusieurs fois des mêmes données au sein d'une transaction. Avant la fin de cette transaction, une autre transaction accède également aux mêmes données. Ensuite, entre les deux lectures de données de la première transaction, du fait de la modification de la deuxième transaction, les données lues deux fois par la première transaction peuvent être différentes. De cette façon, les données lues deux fois au sein d’une transaction sont différentes, on parle donc de lecture non répétable. Par exemple, un éditeur lit deux fois le même document, mais entre les lectures, l'auteur réécrit le document. Lorsque l'éditeur lit le document une seconde fois, le document a changé. Les lectures brutes ne sont pas reproductibles. Ce problème peut être évité si les éditeurs ne peuvent lire le document qu'une fois que l'auteur a fini de l'écrire.
3. Lecture fantôme : fait référence à un phénomène qui se produit lorsque les transactions ne sont pas exécutées indépendamment. Par exemple, la première transaction modifie les données d'une table, et cette modification concerne toutes les lignes de données de la table. Parallèlement, la deuxième transaction modifie également les données de cette table. Cette modification insère une ligne de nouvelles données dans la table. Puis, à l’avenir, l’utilisateur qui effectue la première transaction constatera qu’il reste des lignes de données non modifiées dans la table, comme si une hallucination s’était produite. Par exemple, un éditeur modifie un document soumis par un auteur, mais lorsque la production fusionne ses modifications dans la copie principale du document, on découvre que l'auteur a ajouté du nouveau matériel non édité au document. Ce problème peut être évité si personne ne peut ajouter de nouveaux éléments au document tant que les éditeurs et le service de production n'ont pas fini de travailler sur le document original.
4. Le premier type de perte de mise à jour (perte de restauration) :
Lorsque deux transactions mettent à jour la même source de données, si la première transaction est validée et l'autre transaction est révoquée, alors la première transaction sera Les mises à jour effectuées par l'entreprise ont également été annulés. En d’autres termes, la dernière transaction effectuée par la première transaction est perdue.
5. Le deuxième type de perte de mise à jour (perte par écrasement) :
Le deuxième type de perte de mise à jour est un problème de concurrence souvent rencontré dans les applications pratiques. Il s'agit essentiellement du même type de problème de concurrence que la lecture non reproductible. Habituellement, cela est considéré comme un cas particulier de lectures non répétables : lorsque deux transactions ou plus
interrogent
le même enregistrement puis mettent chacune à jour la ligne en fonction des résultats de la requête d'origine, le deuxième type de mise à jour perdue se produira . Parce que chaque transaction ignore l'existence d'autres transactions, les modifications apportées par la dernière transaction à l'enregistrement écraseront les mises à jour validées effectuées par d'autres transactions sur l'enregistrement...Supplément : Déclaration Spring basée sur les métadonnées Affaires sexuelles :
L'attribut d'isolement

prend en charge un total de cinq paramètres de transaction, les détails sont les suivants :

l          DEFAULT 使用数据库设置的隔离级别 ( 默认 ) ,由 DBA 默认的设置来决定隔离级别 . 
l          READ_UNCOMMITTED 会出现脏读、不可重复读、幻读 ( 隔离级别最低,并发性能高 ) 
l          READ_COMMITTED  会出现不可重复读、幻读问题(锁定正在读取的行) 
l          REPEATABLE_READ 会出幻读(锁定所读取的所有行) 
l          SERIALIZABLE 保证所有的情况不会发生(锁表)

L'objectif de la lecture non répétable est la modification :
Dans les mêmes conditions, les données que vous avez lues, relisez-les et constatez que la valeur est différente
L'objectif de la lecture fantôme est de ajouter ou supprimer
Dans les mêmes conditions, le nombre d'enregistrements lus pour la première et la deuxième fois est différent

---------------------------------- -- ----------------------------------
Types de comportement de propagation des transactions

Spring dans TransactionDefinition Interface spécifie 7 types de comportements de propagation de transaction

Ils spécifient les méthodes de transaction et la façon dont les transactions sont propagées lorsque des appels imbriqués aux méthodes de transaction se produisent :

Tableau 1 Propagation des transactions. Type de comportement

Type de comportement de propagation de la transaction
Description

PROPAGATION_REQUIRED
S'il n'y a pas de transaction en cours, créez une nouvelle transaction. S'il existe déjà une transaction, ajoutez-la à cette transaction. . C'est le choix le plus courant.

PROPAGATION_SUPPORTS
Prend en charge la transaction en cours S'il n'y a pas de transaction actuellement, elle sera exécutée de manière non transactionnelle.

PROPAGATION_MANDATORY
Utilisez la transaction en cours. S'il n'y a pas de transaction en cours, lancez une exception.

PROPAGATION_REQUIRES_NEW
Créer une nouvelle transaction Si une transaction existe actuellement, suspendez la transaction en cours.

PROPAGATION_NOT_SUPPORTED
Effectuer des opérations de manière non transactionnelle. Si une transaction existe actuellement, suspendez la transaction en cours.

PROPAGATION_NEVER
Exécuté de manière non transactionnelle, si une transaction existe actuellement, une exception sera levée.

PROPAGATION_NESTED
Si une transaction existe actuellement, elle sera exécutée au sein de la transaction imbriquée. S'il n'y a aucune transaction en cours, effectuez des opérations similaires à PROPAGATION_REQUIRED.

------------------------------------------------------ ------ -------------
Simple signifie qu'aucun modèle n'est nécessaire. xhtml est la valeur par défaut, avec certains modules fournis par struts2
Par exemple, c'est possible. pour ajouter form ...>

traitement des messages d'erreur et vérification des pages Jetez un œil à struts.properties
ou


Le dernier, comme son nom l'indique, est combiné avec du CSS pour gérer ces contenus. Si vous êtes débutant, vous n'avez pas besoin d'en tenir compte. Si vous ne souhaitez pas que le contenu de ce modèle ait un impact sur votre développement, vous pouvez le modifier en simple.
org/apache/struts2/default.properties
struts.ui.theme=xhtml  
struts.ui.templateDir=template  
struts.ui.templateSuffix=ftl  
你可以在struts.xml中添加
<constant name="struts.ui.theme" value="simple" />来修改这个参数
Si votre page utilise la mise en page CSS et que vous souhaitez utiliser les fonctions améliorées de struts2, utilisez css_xhtml pour obtenir une meilleure expérience utilisateur.



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
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
Rôle de MySQL: Bases de données dans les applications WebRôle de MySQL: Bases de données dans les applications WebApr 17, 2025 am 12:23 AM

Le rôle principal de MySQL dans les applications Web est de stocker et de gérer les données. 1.MySQL traite efficacement les informations utilisateur, les catalogues de produits, les enregistrements de transaction et autres données. 2. Grâce à SQL Query, les développeurs peuvent extraire des informations de la base de données pour générer du contenu dynamique. 3.MySQL fonctionne basé sur le modèle client-serveur pour assurer une vitesse de requête acceptable.

MySQL: Construire votre première base de donnéesMySQL: Construire votre première base de donnéesApr 17, 2025 am 12:22 AM

Les étapes pour construire une base de données MySQL incluent: 1. Créez une base de données et une table, 2. Insérer des données et 3. Conduisez des requêtes. Tout d'abord, utilisez les instructions CreateDatabase et CreateTable pour créer la base de données et la table, puis utilisez l'instruction InsertInto pour insérer les données, et enfin utilisez l'instruction SELECT pour interroger les données.

MySQL: une approche adaptée aux débutants du stockage de donnéesMySQL: une approche adaptée aux débutants du stockage de donnéesApr 17, 2025 am 12:21 AM

MySQL convient aux débutants car il est facile à utiliser et puissant. 1.MySQL est une base de données relationnelle et utilise SQL pour les opérations CRUD. 2. Il est simple à installer et nécessite la configuration du mot de passe de l'utilisateur racine. 3. Utilisez l'insertion, la mise à jour, la suppression et la sélection pour effectuer des opérations de données. 4. OrderBy, où et jointure peut être utilisé pour des requêtes complexes. 5. Le débogage nécessite de vérifier la syntaxe et d'utiliser Expliquez pour analyser la requête. 6. Les suggestions d'optimisation incluent l'utilisation d'index, le choix du bon type de données et de bonnes habitudes de programmation.

MySQL est-il adapté aux débutants? Évaluation de la courbe d'apprentissageMySQL est-il adapté aux débutants? Évaluation de la courbe d'apprentissageApr 17, 2025 am 12:19 AM

MySQL convient aux débutants car: 1) facile à installer et à configurer, 2) Riches Ressources d'apprentissage, 3) Syntaxe SQL intuitive, 4) Prise en charge de l'outil puissant. Néanmoins, les débutants doivent surmonter des défis tels que la conception de la base de données, l'optimisation des requêtes, la gestion de la sécurité et la sauvegarde des données.

SQL est-il un langage de programmation? Clarifier la terminologieSQL est-il un langage de programmation? Clarifier la terminologieApr 17, 2025 am 12:17 AM

Oui, sqlisaprogrammingNanguages ​​en matière de responsabilité de responsabilité.

Expliquez les propriétés acides (atomicité, cohérence, isolement, durabilité).Expliquez les propriétés acides (atomicité, cohérence, isolement, durabilité).Apr 16, 2025 am 12:20 AM

Les attributs acides comprennent l'atomicité, la cohérence, l'isolement et la durabilité, et sont la pierre angulaire de la conception de la base de données. 1. L'atomicité garantit que la transaction est complètement réussie ou complètement échouée. 2. La cohérence garantit que la base de données reste cohérente avant et après une transaction. 3. L'isolement garantit que les transactions n'interfèrent pas entre elles. 4. La persistance garantit que les données sont enregistrées en permanence après la soumission des transactions.

MySQL: Système de gestion de la base de données vs langage de programmationMySQL: Système de gestion de la base de données vs langage de programmationApr 16, 2025 am 12:19 AM

MySQL n'est pas seulement un système de gestion de base de données (SGBD) mais également étroitement lié aux langages de programmation. 1) En tant que SGBD, MySQL est utilisé pour stocker, organiser et récupérer des données et l'optimisation des index peut améliorer les performances de la requête. 2) La combinaison de SQL avec des langages de programmation, intégrés dans Python, en utilisant des outils ORM tels que SQLALCHEMY peut simplifier les opérations. 3) L'optimisation des performances comprend l'indexation, la requête, la mise en cache, la division des bibliothèques et des tableaux et la gestion des transactions.

MySQL: Gestion des données avec les commandes SQLMySQL: Gestion des données avec les commandes SQLApr 16, 2025 am 12:19 AM

MySQL utilise des commandes SQL pour gérer les données. 1. Les commandes de base incluent sélectionner, insérer, mettre à jour et supprimer. 2. L'utilisation avancée implique des fonctions de jointure, de sous-requête et d'agrégation. 3. Les erreurs courantes incluent les problèmes de syntaxe, de logique et de performances. 4. Les conseils d'optimisation incluent l'utilisation d'index, d'éviter la sélection * et l'utilisation de la limite.

See all articles

Outils d'IA chauds

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.

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

AI Hentai Generator

AI Hentai Generator

Générez AI Hentai gratuitement.

Article chaud

R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Meilleurs paramètres graphiques
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Comment réparer l'audio si vous n'entendez personne
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Commandes de chat et comment les utiliser
1 Il y a quelques moisBy尊渡假赌尊渡假赌尊渡假赌

Outils chauds

MinGW - GNU minimaliste pour Windows

MinGW - GNU minimaliste pour Windows

Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.

Version crackée d'EditPlus en chinois

Version crackée d'EditPlus en chinois

Petite taille, coloration syntaxique, ne prend pas en charge la fonction d'invite de code

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

SublimeText3 Linux nouvelle version

SublimeText3 Linux nouvelle version

Dernière version de SublimeText3 Linux

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP