Maison >base de données >tutoriel mysql >Quelles sont les quatre caractéristiques des transactions de base de données ?

Quelles sont les quatre caractéristiques des transactions de base de données ?

青灯夜游
青灯夜游original
2020-10-16 15:08:2524338parcourir

Les quatre caractéristiques des transactions de base de données sont : 1. L'atomicité, une transaction est l'unité logique de travail de la base de données, et toutes les opérations de la transaction sont effectuées ou non 2. La cohérence, avant et après une transaction ; la transaction est exécutée Tout doit être dans un état cohérent par la suite ; 3. Isolement ; 4. Durabilité Une fois qu'une transaction est soumise, ses modifications dans les données de la base de données doivent être permanentes.

Quelles sont les quatre caractéristiques des transactions de base de données ?

(Tutoriel recommandé : Tutoriel vidéo MySQL )

Si une base de données prétend prendre en charge les opérations de transaction, alors la base de données Il doit avoir les quatre caractéristiques suivantes :

1. Atomicité (Atomicité)

Atomicité signifie que toutes les opérations incluses dans la transaction réussissent toutes ou échouent toutes. c'est le même concept que la fonction des transactions introduite dans les deux blogs précédents. Par conséquent, si l'opération de transaction réussit, elle doit être entièrement appliquée à la base de données. Si l'opération échoue, elle ne peut avoir aucun impact sur la base de données.

2. Cohérence

La cohérence signifie qu'une transaction doit transformer la base de données d'un état de cohérence à un autre, c'est-à-dire qu'une transaction doit être dans un état cohérent avant et après son exécution.

Prenons l'exemple du transfert, en supposant que l'argent total de l'utilisateur A et de l'utilisateur B est de 5 000, alors peu importe la manière dont le transfert se déroule entre A et B, ou le nombre de fois que le transfert est effectué, l'argent de les deux utilisateurs seront les mêmes une fois la transaction terminée. Le total devrait atteindre 5 000, ce qui correspond à la cohérence de la transaction.

3. Isolement

L'isolement se produit lorsque plusieurs utilisateurs accèdent à la base de données simultanément, par exemple lors de l'utilisation de la même table, la base de données est activée pour chaque utilisateur. La transaction ne peut pas être perturbée par les opérations d'autres transactions, et plusieurs transactions simultanées doivent être isolées les unes des autres.

C'est-à-dire pour obtenir un tel effet : pour deux transactions simultanées T1 et T2, du point de vue de la transaction T1, T2 se termine avant le début de T1, ou commence après la fin de T1, donc chaque transaction ignore que d'autres transactions s'exécutent simultanément.

À propos de l'isolation des transactions La base de données fournit plusieurs niveaux d'isolation, qui seront introduits ultérieurement.

4. Durabilité

La durabilité signifie qu'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 l'opération de validation des transactions ne le sera pas. être perdu même si le système de base de données rencontre une panne.

Par exemple, lorsque nous utilisons JDBC pour faire fonctionner la base de données, après avoir soumis la méthode de transaction, l'utilisateur est invité à indiquer que l'opération de transaction est terminée. Lorsque l'exécution de notre programme est terminée, jusqu'à ce que nous voyions l'invite, nous pouvons l'identifier. la transaction et soumettez-la correctement, même si la base de données est Si un problème survient, notre transaction doit être entièrement exécutée, sinon nous verrons une erreur majeure qui incitera à terminer la transaction, mais la base de données n'a pas exécuté la transaction en raison d'un échec.

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