IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

MS SQL Server Discussion :

requette pr doublon


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    381
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : Maroc

    Informations forums :
    Inscription : Novembre 2007
    Messages : 381
    Par défaut requette pr doublon
    Salut
    Vous pouvez me dire c'est quoi la requête pour savoir s'il y a des doublons dans la table svp?
    Merci

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 999
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 999
    Billets dans le blog
    6
    Par défaut
    Cela dépend...

    Lisez l'article que j'ai écrit à ce sujet : http://sqlpro.developpez.com/cours/doublons/

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    381
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : Maroc

    Informations forums :
    Inscription : Novembre 2007
    Messages : 381
    Par défaut
    Salut,
    J'ai des doublons dans une table je veux les supprimés en gardant une seule copie, j'ai testé avec cette requête mais elle ne marche pas.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    delete table
    where champ=(select count(champ)
    from table
    having count(champ)>1)
    Merci de me repondre

  4. #4
    Expert confirmé
    Avatar de mikedavem
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2005
    Messages
    5 450
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Distribution

    Informations forums :
    Inscription : Août 2005
    Messages : 5 450
    Par défaut
    Bonjour,

    Effectivement votre requête ne fonctionnera pas car vous essayez de comparer des noms de champs avec des comptes de champ

    Il faudrait avoir la structure de votre table et le type de doublon qu'elle contient pour pouvoir vous aider

    L'article de SQL Pro permettra très certainement de vous aider

    SL Pro a dit : Lisez l'article que j'ai écrit à ce sujet : http://sqlpro.developpez.com/cours/doublons/

  5. #5
    Membre éclairé
    Profil pro
    Inscrit en
    Novembre 2007
    Messages
    381
    Détails du profil
    Informations personnelles :
    Âge : 42
    Localisation : Maroc

    Informations forums :
    Inscription : Novembre 2007
    Messages : 381
    Par défaut
    Bonjour,
    J'ai une table qu'elle a des doublons. Les doublons c'est le code siren des societes, je veux virer toutes les societes qui on le même siren et garder juste une.
    Par exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    1         325753275
    2         325753275
    3         325753275
    4         325753275
    5         325753275
    Je veux virer par exemple 4 enregistrements et garder un.
    Aidez moi SVP.

  6. #6
    Expert confirmé
    Avatar de mikedavem
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2005
    Messages
    5 450
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Ain (Rhône Alpes)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Distribution

    Informations forums :
    Inscription : Août 2005
    Messages : 5 450
    Par défaut
    Une solution pourrait ête çà je pense (peut être pas la meilleure .. a voir)

    - En admettant que votre table comporte une colonne IDENTITY
    - Exemple avec une table SIREN avec la structure que vous avez proposé)


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
     
    -- Récupération enregistrements en doublons 
    SELECT MIN(id) AS id,siren INTO #TEMP_SIREN
    FROM SIREN
    WHERE siren IN 
    (
    	SELECT	siren 
    	FROM	SIREN
    	GROUP BY siren
    	HAVING COUNT(siren) > 1
    )
    GROUP BY siren
    GO
     
    -- Suppression des doublons
    DELETE 
    FROM SIREN
    WHERE EXISTS (
    	SELECT *
    	FROM	SIREN S1
    	WHERE	SIREN.siren = S1.siren
    	GROUP BY S1.siren
    	HAVING COUNT(*) > 1
    )
     
    -- Désactivation IDENTITY AUTO
    SET IDENTITY_INSERT SIREN ON
    GO
     
    -- insertion contenu table temporaire
    INSERT INTO SIREN (id,siren)
    SELECT * FROM #TEMP_SIREN
     
    -- Réactivation IDENTITY AUTO
    SET IDENTITY_INSERT SIREN OFF
    GO
     
    -- Suppression table temporaire
    DROP TABLE #TEMP_SIREN

Discussions similaires

  1. Requette avec doublons
    Par aityahia dans le forum Langage SQL
    Réponses: 3
    Dernier message: 06/12/2006, 11h35
  2. PB: Insertion de doublon
    Par maxvador dans le forum MS SQL Server
    Réponses: 6
    Dernier message: 04/09/2003, 12h07
  3. Réponses: 2
    Dernier message: 19/08/2003, 18h04
  4. tri a bulle sans les doublons
    Par comme de bien entendu dans le forum Algorithmes et structures de données
    Réponses: 4
    Dernier message: 10/03/2003, 16h29
  5. verification de doublons dans un tableau
    Par bohemianvirtual dans le forum C
    Réponses: 11
    Dernier message: 25/05/2002, 12h21

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo