Maison > base de données > tutoriel mysql > Comment puis-je exécuter des requêtes MySQL SELECT sans verrouillage ?

Comment puis-je exécuter des requêtes MySQL SELECT sans verrouillage ?

Susan Sarandon
Libérer: 2024-12-15 10:25:11
original
971 Les gens l'ont consulté

How Can I Execute MySQL SELECT Queries Without Locking?

Les requêtes MySQL peuvent-elles être exécutées sans provoquer de verrouillage ?

Dans MySQL, des requêtes telles que SELECT COUNT(online.account_id) cnt depuis en ligne peuvent provoquer par inadvertance des verrous de base de données, en particulier lorsque les tables comme en ligne sont sujettes à des modifications fréquentes par des événements externes. Pour atténuer ce problème, il est important de comprendre si MySQL propose des mécanismes pour exécuter des instructions select sans déclencher de verrous.

Une solution potentielle consiste à utiliser le niveau d'isolation des transactions READ-UNCOMMITTED. Cependant, cette approche peut ne pas être compatible avec les configurations de bases de données esclaves, car elle peut entraîner des erreurs de journalisation binaire.

Une technique alternative consiste à utiliser la commande SET pour ajuster temporairement le niveau d'isolement des transactions sur READ UNCOMMITTED, exécutez le select, puis réinitialisez le niveau d'isolement sur REPEATABLE READ. Cette méthode peut être efficacement implémentée comme suit :

SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED ;
SELECT * FROM TABLE_NAME ;
SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ ;
Copier après la connexion

Pour les bases de données esclaves, une approche plus appropriée consiste à utiliser la commande COMMIT au lieu de la commande SET pour inverser le niveau d'isolation après l'exécution de l'instruction select. Ceci peut être réalisé en employant la séquence suivante :

SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED ;
SELECT * FROM TABLE_NAME ;
COMMIT ;
Copier après la connexion

En incorporant ces techniques, les utilisateurs de MySQL peuvent exécuter des instructions select sans induire de verrous, résolvant ainsi efficacement le problème décrit dans la requête d'origine.

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