Maison > Article > base de données > Comment obtenir un verrouillage au niveau des lignes dans les tables MyISAM de MySQL ?
Verrouillage d'une seule ligne dans la table MyISAM
Dans MySQL, les tables MyISAM ne prennent pas en charge le verrouillage au niveau des lignes. Cependant, si vous avez besoin de fonctionnalités de verrouillage au niveau des lignes, vous pouvez envisager de passer à InnoDB, qui fournit cette fonctionnalité.
Passer à InnoDB pour le verrouillage au niveau des lignes
Pour activez le verrouillage au niveau des lignes, vous devez convertir votre table utilisateur de MyISAM en InnoDB. Vous pouvez le faire en utilisant la commande suivante :
ALTER TABLE <user_table> ENGINE=InnoDB;
Une fois que vous avez converti en InnoDB, vous pouvez utiliser l'instruction SELECT ... FOR UPDATE pour obtenir un verrou exclusif sur une ligne particulière. Cela empêchera les autres sessions de modifier ou d'accéder à la ligne verrouillée jusqu'à ce que le verrou soit libéré.
Voici un exemple :
SELECT * FROM <user_table> WHERE <condition> FOR UPDATE;
Remarque : Vous devez libérer le verrou rapidement après avoir terminé vos opérations sur la ligne. Cela peut être fait en émettant une instruction COMMIT ou ROLLBACK.
Ressources supplémentaires :
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!