Maison > base de données > tutoriel mysql > Comment puis-je effectuer des requêtes SELECT non verrouillables dans MySQL ?

Comment puis-je effectuer des requêtes SELECT non verrouillables dans MySQL ?

Mary-Kate Olsen
Libérer: 2024-12-15 16:56:15
original
201 Les gens l'ont consulté

How Can I Perform Non-Locking SELECT Queries in MySQL?

Requêtes SELECT non verrouillables dans MySQL

Dans MySQL, des verrouillages fréquents lors des opérations SELECT peuvent survenir lorsque les tables sont modifiées simultanément. Pour atténuer ce problème, envisagez d'utiliser des techniques permettant des lectures non verrouillables.

Utilisation de READ UNCOMMITTED

Une approche consiste à définir le niveau d'isolement des transactions sur READ UNCOMMITTED, ce qui permet des lectures sans acquérir de verrous. Cependant, cette option peut ne pas convenir aux esclaves car elle compromet l'intégrité des données.

L'équivalent SQL de AVEC (NOLOCK)

Pour l'équivalence avec le AVEC (NOLOCK) clause dans Microsoft SQL Server, MySQL propose un processus en plusieurs étapes :

  1. Démarrez la transaction avec READ UNCOMMITTED isolement :

    SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;
    Copier après la connexion
  2. Effectuez la requête SELECT :

    SELECT * FROM TABLE_NAME;
    Copier après la connexion
  3. Réinitialisez le niveau d'isolement des transactions sur LECTURE RÉPÉTABLE :

    SET SESSION TRANSACTION ISOLATION LEVEL REPEATABLE READ;
    Copier après la connexion

Requête non verrouillable améliorée Exécution

Michael Mior a proposé une version améliorée de l'exécution de requêtes non verrouillables :

  1. Définissez le niveau d'isolement des transactions sur READ UNCOMMITTED :

    SET TRANSACTION ISOLATION LEVEL READ UNCOMMITTED ;
    Copier après la connexion
  2. Effectuer le SELECT requête :

    SELECT * FROM TABLE_NAME ;
    Copier après la connexion
  3. Valider la transaction :

    COMMIT ;
    Copier après la connexion

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