Rechercher : dans
Par :

Comment dans une table enleveé les doublons

Dernière réponse le 20 fév 2008 à 15:17:56 DiabloAndSab, le 15 fév 2008 à 12:28:03 
 Signaler ce message aux modérateurs

Bonjour à tous,
mon problème est le suivant j'ai une table conséquente qui contient un grand nombre d'enregistrement. Et j'aurai besoins de supprimer des doublons qui ne sont pas dans l'identifiant mais dans trois champs nom, prenom et date de naissance. Merci d'avance de votre aide.

Meilleures réponses pour « Comment dans une table enleveé les doublons » dans :
MySQL - Supprimer des doublons dans une table Voir Pour supprimer des doublons au niveau d'une table donnée définie comme suit : CREATE TABLE IF NOT EXISTS TabTest ( cle_prim integer(4) NOT NULL auto_increment, x integer, y integer, z integer, ...
Eviter les doublons dans Excel VoirEviter les doublons lors d'un encodage dans un colonne de feuille excel: prendre le format conditionnel sur le première cellule sous les titres (par ex A2) choisir la formule suivante : =NB.SI($A$2:$A$21;A2)>1 mettre là la couleur de fond...
Enlever la bordure sur une image dans un lien en HTML/CSS VoirVous avez fait une image cliquable en mettant une balise IMG au sein d'un lien et le navigateur vous affiche un cadre ou plus exactement une bordure autour de l'image. Il existe deux façons de supprimer cette bordure...
Manipulations élémentaires des tableaux sous MatLab VoirSommaire I. Stockage des tableaux II. L'indexation linéaire II.1. Accéder à un élément d'un tableau en utilisant l'indexation linéaire II.2. Passer d'une indexation à l'autre II.2.1. La fonction ind2sub II.2.2. La fonction sub2ind III. La...
Tableaux HTML VoirUtilisation de tableaux Il est souvent utile de présenter des informations mieux structurées qu'avec des listes. Les tableaux permettent de les afficher en lignes et en colonnes. Les tableaux sont définis comme étant des suites de lignes. Un...
SQL - Modification de table VoirModification de table Il est possible de supprimer une table grâce à la clause DROP, il existe aussi des commandes moins extrêmes permettant L'ajout de colonnes La modification de colonnes La suppression de colonnes Enfin, il est possible...
Javascript - Les tableaux VoirIntroduction à la notion de tableau Les variables de Javascript ne permettent de stocker qu'une seule donnée à la fois. Or, étant donné qu'il est souvent utile de manipuler de nombreuses données, le concept de variable se révéle parfois...

1

ceddec, le 15 fév 2008 à 12:41:35

Bonjour,

Une solution serait d'utiilser une sous requete. Ta requete principale efface toutes les lignes qui sont dans les lignes déjà examinées (fait par la sous-requete).
Dis autrement, la sous requete retourne toutes les lignes identiques à la ligne courante (de la requete principale) parmis celles qui ont déjà été examinées et si cette sous requete retourne une ligne, alors la requete principale effectue la suppression
Avec de la patience, on arrive à tout

Répondre à ceddec

4

DiabloAndSab, le 18 fév 2008 à 09:37:54

Bonjour à tous j'ai essayé une requete Sql mais elle ne fonctionne pas.

delete from insc_mdc_ancien2 where Nom, Prenom, Naissance Not In (
select distinct (Nom),Prenom,Naissance from insc_mdc_ancien2)

Merci d'avance pour votre aide!

Répondre à DiabloAndSab

2

DiabloAndSab, le 15 fév 2008 à 13:49:03

Ca serait dans ce genre la?

Delete from ins_mdc_ancien
Select nom, prenom, datenaiss from ins_mdc_ancien
where nom=nom and prenom=prenom and datenaiss=datenaiss;

Sinon est ce que quelqu'un pourrait me donner un exemple...

Merci d'avance

Répondre à DiabloAndSab

3

DiabloAndSab, le 15 fév 2008 à 14:59:37

Vu que personne me répond je dois mal m'expliquer. Donc je voudrais retiré tous les doublons (les doublons sont identifiables par 3 champs nom, prenom et date naissance) présents dans ma table.
Merci de votre aide

Répondre à DiabloAndSab

5

ceddec, le 18 fév 2008 à 14:04:28

Bonjour,

la requete serait plus du genre :

delete from insc_mdc_ancien2 t1
where 1 < (select count(distinct nom, prenom, datenais)
from insc_mdc_ancien2 t2
where t1.nom= t2.nom and t1.prenom = t2.prenom and t1.datenais=t2.datenais)

J'ai pas testé cette requete mais ca peut te donner une idée

Voici un lien qui parle des sous-requetes et qui pourra t'aider
http://sqlpro.developpez.com/cours/sqlaz/sousrequetes/


Bon courage
Avec de la patience, on arrive à tout

Répondre à ceddec

6

DiabloAndSab, le 18 fév 2008 à 14:38:16

Merci pour ta réponse.
Par contre MySql détecte une erreur:

Erreur

requête SQL: Documentation

DELETE FROM insc_mdc_ancien2 t1 WHERE 1 < ( SELECT count( DISTINCT nom, prenom, datenais )
FROM insc_mdc_ancien2 t2
WHERE t1.nom = t2.nom
AND t1.prenom = t2.prenom
AND t1.datenais = t2.datenais )

MySQL a répondu:Documentation
#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'where 1 < (select count(distinct nom, prenom, datenais)
from insc_mdc_ancien2 t' at line 2

Si vous avez une idées merci de me la faire parvenir!
Merci d'avance.

Répondre à DiabloAndSab

7

DiabloAndSab, le 18 fév 2008 à 16:09:12

Je me rapproche mais je trouve pas ce qui cloche:

Erreur

requête SQL: Documentation

DELETE t1 FROM insc_mdc_ancien2 WHERE 1 < ( SELECT count( DISTINCT Nom, Prenom, Naissance )
FROM insc_mdc_ancien2 t2
WHERE t1.Nom = t2.Nom
AND t1.Prenom = t2.Prenom
AND t1.Naissance = t2.Naissance )

MySQL a répondu:Documentation
#1109 - Unknown table 't1' in MULTI DELETE

Merci Ceddec vu qu'il n'y a que toi qui m'aide...

Répondre à DiabloAndSab

8

ceddec, le 18 fév 2008 à 20:33:41

De rien

Pour ta dernière requete il faut mettre le t1 après le nom de ta table :

DELETE FROM insc_mdc_ancien2 t1
WHERE 1 < ( SELECT count( DISTINCT Nom, Prenom, Naissance )
FROM insc_mdc_ancien2 t2
WHERE t1.Nom = t2.Nom
AND t1.Prenom = t2.Prenom
AND t1.Naissance = t2.Naissance )

Si cette requete ne marche pas, tu peux essayer cette variante (il faut MySql 4.1.0 minimum) :

DELETE FROM insc_mdc_ancien2 t1
WHERE EXISTS ( SELECT *
FROM insc_mdc_ancien2 t2
WHERE t1.Nom = t2.Nom
AND t1.Prenom = t2.Prenom
AND t1.Naissance = t2.Naissance
HAVING count( DISTINCT Nom, Prenom, Naissance )>=2)
Avec de la patience, on arrive à tout

Répondre à ceddec

9

DiabloAndSab, le 19 fév 2008 à 09:31:53

Je me rend que j'ai oublié de te spécifié la version que j'utilise. En faite je travail sous wamp5 dont MySql 5.0.45 et du php5.

Pour la première requete j'obtiens ça:

Erreur

requête SQL: Documentation

DELETE FROM insc_mdc_ancien2 t1 WHERE 1 < ( SELECT count( DISTINCT Nom, Prenom, Naissance )
FROM insc_mdc_ancien2 t2
WHERE t1.Nom = t2.Nom
AND t1.Prenom = t2.Prenom
AND t1.Naissance = t2.Naissance )

MySQL a répondu:Documentation
#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'WHERE 1 < ( SELECT count( DISTINCT Nom, Prenom, Naissance )
FROM insc_mdc_ancie' at line 2


Et pour la deuxieme requete j'obtiens ça:
Erreur

requête SQL: Documentation

DELETE FROM insc_mdc_ancien2 t1 WHERE EXISTS (
SELECT *
FROM insc_mdc_ancien2 t2
WHERE t1.Nom = t2.Nom
AND t1.Prenom = t2.Prenom
AND t1.Naissance = t2.Naissance
HAVING count( DISTINCT Nom, Prenom, Naissance ) >=2
)

MySQL a répondu:Documentation
#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'WHERE EXISTS ( SELECT *
FROM insc_mdc_ancien2 t2
WHERE t1.Nom = t2.Nom
AND t1' at line 2

Par contre quand je place le t1 comme ceci il me demande une vrai validation (Voulez vous vraiment executer cette requête mais ensuite il y a un message d'erreur
Erreur

requête SQL: Documentation

DELETE t1 FROM insc_mdc_ancien2 WHERE 1 < ( SELECT count( DISTINCT Nom, Prenom, Naissance )
FROM insc_mdc_ancien2 t2
WHERE t1.Nom = t2.Nom
AND t1.Prenom = t2.Prenom
AND t1.Naissance = t2.Naissance )

MySQL a répondu:Documentation
#1109 - Unknown table 't1' in MULTI DELETE

Merci de ton aide

Répondre à DiabloAndSab

10

ceddec, le 20 fév 2008 à 08:46:20

Bonjour,

Désolé de ne pas pouvoir répondre plus vite mais j'ai quelques soucis de pc.
Sinon je crois avoir compris l'erreur:

Il s'agit en fait d'une erreur dans la sous requête. En effet, il est impossible de faire un count(distinct a, b). La solution est de concatener tout tes champs ainsi il ne devrait plus y avoir de problème.
La requête deviendrait :

DELETE FROM insc_mdc_ancien2 t1
WHERE 1 < ( SELECT count( DISTINCT concat(Nom, Prenom, Naissance) )
FROM insc_mdc_ancien2 t2
WHERE t1.Nom = t2.Nom
AND t1.Prenom = t2.Prenom
AND t1.Naissance = t2.Naissance ) 


et la deuxième solution :
DELETE FROM insc_mdc_ancien2 t1
WHERE EXISTS ( SELECT *
FROM insc_mdc_ancien2 t2
WHERE t1.Nom = t2.Nom
AND t1.Prenom = t2.Prenom
AND t1.Naissance = t2.Naissance
HAVING count( DISTINCT concat(Nom, Prenom, Naissance) )>=2) 


Il est possible que les requêtes ne marchent pas si le champ Naissance n'est pas une chaine de caractère. Dans ce cas, il faut faire un cast :
CAST(Naissance as VARCHAR)

Avec de la patience, on arrive à tout

Répondre à ceddec

11

DiabloAndSab, le 20 fév 2008 à 11:10:29

Désolé mais ça ne fonctionne toujours pas même en ayant change le format de naissance en varchar:
Erreur

requête SQL: Documentation

DELETE FROM insc_mdc_ancien2 t1 WHERE EXISTS (
SELECT *
FROM insc_mdc_ancien2 t2
WHERE t1.Nom = t2.Nom
AND t1.Prenom = t2.Prenom
AND t1.Naissance = t2.Naissance
HAVING count( DISTINCT concat( Nom, Prenom, Naissance ) ) >=2
)

MySQL a répondu:Documentation
#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'WHERE EXISTS ( SELECT *
FROM insc_mdc_ancien2 t2
WHERE t1.Nom = t2.Nom
AND t1' at line 2



Erreur

requête SQL: Documentation

DELETE FROM insc_mdc_ancien2 t1 WHERE 1 < ( SELECT count( DISTINCT concat( Nom, Prenom, Naissance ) )
FROM insc_mdc_ancien2 t2
WHERE t1.Nom = t2.Nom
AND t1.Prenom = t2.Prenom
AND t1.Naissance = t2.Naissance )

MySQL a répondu:Documentation
#1064 - You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'WHERE 1 < ( SELECT count( DISTINCT concat(Nom, Prenom, Naissance) )
FROM insc_m' at line 2

C'est pas grave car j'ai beaucoup de choses à faire nous je m'occupe en attendant ta réponse.
Par contre dis le moi si tu sèche que je ne t'attende pas trop.
Merci de ton aide qui reste bien la seule à s'être intéressé à mon problème.

Répondre à DiabloAndSab

12

DiabloAndSab, le 20 fév 2008 à 11:21:39

Je crois que dans cette page y a peut être une solution: http://translate.google.com/...

S'il est documentée dans ces pages, cela prend un peu de chasse pour confirmer cette modification incompatible v3.23 à v4.1:

If you delete all rows from a table with DELETE FROM tablename, then add some new rows with INSERT INTO tablename, an AUTO_INCREMENT field would start again from 1 using MySQL v3.23.

Si vous supprimez toutes les lignes d'une table avec DELETE FROM tablename, puis ajouter de nouvelles lignes avec INSERT INTO tablename, un champ AUTO_INCREMENT serait à nouveau à compter de 1 en utilisant MySQL v3.23.

Dommage que ce soit de l'anglais.

Je vais essayer ce qu'il ont dit.

Répondre à DiabloAndSab

13

 DiabloAndSab, le 20 fév 2008 à 15:17:56

J'ai un peu prés trouvé car je ne récupère pas tous les données mais ça fonction. Je créer une table en copiant la pécèdente puis je la vide et ensuite j'applique ma requête:
select distinct( Nom), Prenom, Naissance from insc_mdc_ancien2 order by Nom
et ensuite j'exporte les résultats de la requete vers ma nouvelle table.
Cependant quand on fait le transfert selon le nombre d'enregistrements Sql remet l'insert into ce qui arrete la procédure quand on fait un copié coller gloable. Voilà c'est tout.

Un très grand merci a ceddec qui a été le seul à m'aider. MERCI a TOI

Répondre à DiabloAndSab