Maison >base de données >tutoriel mysql >Comment puis-je exécuter des requêtes MySQL SELECT sans verrouillage ?
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 ;
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 ;
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!