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