Maison > base de données > tutoriel mysql > Comment supprimer les lignes en double d'une table SQL sans l'erreur « Vous ne pouvez pas spécifier la table cible... » ?

Comment supprimer les lignes en double d'une table SQL sans l'erreur « Vous ne pouvez pas spécifier la table cible... » ?

Linda Hamilton
Libérer: 2024-11-01 01:12:01
original
1023 Les gens l'ont consulté

How to Delete Duplicate Rows from an SQL Table without the

Suppression des lignes en double d'une table SQL

Dans la gestion de bases de données, il est souvent nécessaire de supprimer les enregistrements en double d'une table. MySQL propose différentes façons d'y parvenir.

Une approche courante consiste à identifier les lignes en double à l'aide d'une requête telle que :

SELECT COUNT(empssn), empssn FROM employee GROUP BY empssn HAVING COUNT(empssn) > 1
Copier après la connexion

Cette requête identifie les lignes avec des valeurs en double dans la colonne empssn. Pour supprimer ces doublons, vous pouvez utiliser la requête suivante :

DELETE FROM employee WHERE (empid, empssn) NOT IN (SELECT MIN(empid), empssn FROM employee GROUP BY empssn);
Copier après la connexion

Cependant, cette approche peut entraîner l'erreur "Vous ne pouvez pas spécifier la table cible 'employé' pour la mise à jour dans la clause FROM." Pour résoudre ce problème, vous pouvez envelopper la sous-requête dans une table dérivée :

DELETE FROM employee WHERE (empid, empssn) NOT IN (SELECT empid, empssn FROM (SELECT MIN(empid) AS empid, empssn FROM employee GROUP BY empssn) X);
Copier après la connexion

L'utilisation d'une table dérivée vous permet de référencer la table d'origine dans la sous-requête sans erreur. Cette approche supprime avec succès les lignes en double dans la table des employés tout en préservant la structure des données 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