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 :

Requête conditionnel si table ne contient pas de doublons


Sujet :

MS SQL Server

  1. #1
    Nouveau membre du Club
    Inscrit en
    Novembre 2010
    Messages
    41
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 41
    Points : 32
    Points
    32
    Par défaut Requête conditionnel si table ne contient pas de doublons
    Bonsoir à tous,

    Sur une table T (cf. illustration), je souhaite effectuer une requête SQL permettant de:

    Faire un SELECT * uniquement s'il n'y a pas de doublons sur le champ ID


    ID | NOMS | PRENOM
    --------------------------------------------
    1 | ABCD | TOTO
    2 | DBCA | TATA
    3 | BDCA | TITI

    J'arrive à isoler les doublons avec la fonction suivante, mais comment faire "Planter" la requête si doublons il y a justement.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT            *
     
    FROM            TU
    WHERE            ID in (SELECT            ID
    FROM            ID
    GROUP BY        ID
    HAVING            COUNT(ID)>1 )
    En vous remerciant pour votre aide.

  2. #2
    Membre averti
    Avatar de taibag
    Homme Profil pro
    Étudiant
    Inscrit en
    Septembre 2013
    Messages
    214
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Inde

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2013
    Messages : 214
    Points : 357
    Points
    357
    Billets dans le blog
    1
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT	 *
     
    FROM	 TU
    WHERE	 ID in (SELECT	 ID
    FROM	 ID
    GROUP BY	 ID
    HAVING	 COUNT(ID)>1 )

  3. #3
    Membre averti
    Avatar de taibag
    Homme Profil pro
    Étudiant
    Inscrit en
    Septembre 2013
    Messages
    214
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Inde

    Informations professionnelles :
    Activité : Étudiant
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2013
    Messages : 214
    Points : 357
    Points
    357
    Billets dans le blog
    1
    Par défaut
    Désolé pour la réponse c'était involontaire ;

    Mais tu peux faire cela en code client avec un simple if else.

    NB. utilise les balise code #.

    Cordialement.

  4. #4
    Modérateur

    Profil pro
    dba
    Inscrit en
    Janvier 2010
    Messages
    5 643
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : dba

    Informations forums :
    Inscription : Janvier 2010
    Messages : 5 643
    Points : 13 092
    Points
    13 092
    Par défaut
    Bonjour,

    Faire planter la requete ???

    elle pourrait simplement ne rien renvoyer s'il existe des doublons, et vous avez fait le plus gros du travail ! il suffit de mettre votre requete en tant que condition :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT *
    FROM T
    WHERE NOT EXISTS ( --requete de recherche d'existence de doublon ici )
    Mais il y a certaines choses que je ne comprend pas dans votre requête : est-ce que ID est une table ? (vous faites FROM ID)

    voulez vous vraiment que la requête "plante" avec message d'erreur ? pourquoi ?

    Décrivez mieux vos tables et votre besoin...

  5. #5
    Nouveau membre du Club
    Inscrit en
    Novembre 2010
    Messages
    41
    Détails du profil
    Informations forums :
    Inscription : Novembre 2010
    Messages : 41
    Points : 32
    Points
    32
    Par défaut
    Merci pour vos réponses et disponibilité. La dernière correspond à mon besoin, qui pour répondre à la dernière question est de retour un message d'erreur "Attention présence de doublons" lorsque le résultat de la requête "NOT EXISTS" serait de zéro lignes.


    Pour ce qui est du SELECT in ID, petite coquille désolé. Merci de ne pas en tenir compte.

    En vous remerciant,



    Citation Envoyé par aieeeuuuuu Voir le message
    Bonjour,

    Faire planter la requete ???

    elle pourrait simplement ne rien renvoyer s'il existe des doublons, et vous avez fait le plus gros du travail ! il suffit de mettre votre requete en tant que condition :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SELECT *
    FROM T
    WHERE NOT EXISTS ( --requete de recherche d'existence de doublon ici )
    Mais il y a certaines choses que je ne comprend pas dans votre requête : est-ce que ID est une table ? (vous faites FROM ID)

    voulez vous vraiment que la requête "plante" avec message d'erreur ? pourquoi ?

    Décrivez mieux vos tables et votre besoin...

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 8
    Dernier message: 03/03/2015, 21h12
  2. Réponses: 4
    Dernier message: 10/09/2014, 16h04
  3. Réponses: 0
    Dernier message: 16/02/2009, 23h19
  4. Réponses: 37
    Dernier message: 26/11/2008, 17h10
  5. [SQL] Vérifier si une requête ne contient pas d'erreurs
    Par Sytchev3 dans le forum PHP & Base de données
    Réponses: 3
    Dernier message: 19/10/2007, 16h36

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