Suppression de lignes avec une plage dans MySQL
Lorsque vous tentez de supprimer une plage spécifique de lignes d'une table à l'aide de la clause LIMIT dans MySQL, une erreur peut survenir. Pour illustrer, la requête suivante vise à supprimer une plage de 50 lignes, à partir de la 20ème ligne classée par horodatage dans l'ordre décroissant :
DELETE FROM `chat_messages` ORDER BY `timestamp` DESC LIMIT 20, 50;
Cependant, lors de l'exécution de cette requête, un message d'erreur est rencontré en raison de une syntaxe non valide, en particulier à la valeur OFFSET (50).
Limitation de la clause LIMIT dans l'instruction DELETE
La cause première de l'erreur réside dans l'incapacité d'utiliser OFFSET dans la clause LIMIT des instructions DELETE. Il s'agit d'une distinction significative par rapport aux instructions SELECT, qui permettent à la fois LIMIT et OFFSET de spécifier le point de départ et le nombre de lignes à récupérer.
Solution de contournement pour la suppression de plage
Pour Pour contourner cette limitation, une solution de contournement est nécessaire. En utilisant une sous-requête imbriquée dans l'instruction DELETE, la plage de lignes peut être ciblée et supprimée avec précision. Cette approche implique les étapes suivantes :
Voici un exemple de requête modifiée utilisant cette solution de contournement :
DELETE FROM `chat_messages` WHERE `id` IN ( SELECT `id` FROM ( SELECT `id` FROM `chat_messages` ORDER BY `timestamp` DESC LIMIT 20, 50 ) AS `x` )
Dans cette requête, le principal L'identifiant de la colonne clé est supposé, bien qu'il puisse être modifié par le nom de colonne approprié dans votre scénario spécifique.
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!