Maison > base de données > tutoriel mysql > Comment éviter les conditions de concurrence lors de l'incrémentation de champs dans les bases de données MySQL ?

Comment éviter les conditions de concurrence lors de l'incrémentation de champs dans les bases de données MySQL ?

Patricia Arquette
Libérer: 2024-11-11 06:09:02
original
757 Les gens l'ont consulté

How to Avoid Race Conditions When Incrementing Fields in MySQL Databases?

Éviter les conditions de concurrence dans les bases de données MySQL en incrémentant les mises à jour des champs

Pour éviter les conditions de concurrence dans les bases de données MySQL où plusieurs connexions tentent de mettre à jour le même enregistrement, En particulier lorsqu'il s'agit d'incrémenter un champ tel que « essais », il est essentiel de mettre en œuvre des mesures appropriées.

Une solution efficace consiste à utiliser des mises à jour atomiques. L'utilisation de l'instruction update de MySQL avec une clause WHERE permet des opérations atomiques. Par exemple :

update table set tries=tries+1 where condition=value;
Copier après la connexion

Cette instruction garantit que l'opération d'incrémentation se produit de manière atomique, éliminant ainsi le risque de conditions de concurrence critique.

Alternativement, le verrouillage des lignes peut être utilisé. En utilisant les tables InnoDB au lieu des tables MyISAM, il devient possible de verrouiller les lignes lors des mises à jour. La requête suivante illustre cette approche :

select tries from table where condition=value for update;
.. do application logic to add to `tries`
update table set tries=newvalue where condition=value;
Copier après la connexion

Cette approche empêche les autres requêtes d'accéder à la ligne pendant le traitement des mises à jour, garantissant ainsi que la dernière valeur est renvoyée.

Une autre méthode implique la mise en œuvre un schéma de version. En ajoutant une colonne de version au tableau, les requêtes peuvent être construites comme suit :

select tries,version from table where condition=value;
.. do application logic, and remember the old version value.
update table set tries=newvalue,version=version + 1 where condition=value and version=oldversion;
Copier après la connexion

Cette approche garantit que la mise à jour ne réussit que si la version stockée correspond à la version obtenue au début de la requête. Si la mise à jour échoue, cela indique qu'une autre connexion a modifié la table, et la requête doit être réexécutée.

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!

source:php.cn
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
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal