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

Développement SQL Server Discussion :

Sélectionner un enregistrement parmi plusieurs enregistrements [2008]


Sujet :

Développement SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éprouvé
    Inscrit en
    Avril 2007
    Messages
    1 247
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 1 247
    Par défaut Sélectionner un enregistrement parmi plusieurs enregistrements
    Bonjour,
    Je vais essayer d'être explicite sur ma demande
    Je bloque sur la réalisation d'une requete en sql server.
    Vous trouverez ci dessous, une image ..

    J'ai crée une requête sql toute simple qui m'affiche une liste de BarCode avec un identifiant (champ "Id"). J'ai inséré également un champ ("Nbr_Caractere") qui me donne le nombre de caractère du champ BarCode.
    Le résultat de cette requête me pose un problème. En effet, le champ "Id" peut avoir deux identifiants identiques.
    Pour un identifiant unique , je peux avoir soit un Barcode à 13 caractère ou 28 caractères. Pour ce résultat c'est Ok
    Mais pour 2 identifiants identiques ("Id"), je peux avoir soit un Barcode à 13 caratères ou 28 caractères .Et pour compliquer la tache, pour ces 2 mêmes identifiants ("Id), soit le BarCode à 13 caractères est en première position et le BarCode à 28 caractères en deuxième position ou l'inverse.

    Voici ce que j'essaie de faire :
    Je voudrais que :
    1) Pour un identifiant unique..on ne fait rien: il affiche soir le barceCode à 13 caractère ou à 28 caractères (ligne 2 et 3 de l'image)
    2) Pour deux identifiants identiques, je souhaiterais garder uniquement le BarCode à 13 caratères (ligne 4 et 5 de l'image)

    Nom : BarCode.PNG
Affichages : 236
Taille : 9,2 Ko

    Merci pour votre aide

  2. #2
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 622
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 622
    Billets dans le blog
    10
    Par défaut
    bonjour,

    Comme ceci ?

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    select coalesce(T1.barcod, T2.barcod)
    from ma_table as T1
    left outer join 
         ma_table as T2
      on T2.id=T1.id
     and T2.Nbr_Caractere=28

  3. #3
    Membre éclairé
    Homme Profil pro
    Chef de projet BI
    Inscrit en
    Août 2013
    Messages
    42
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val d'Oise (Île de France)

    Informations professionnelles :
    Activité : Chef de projet BI

    Informations forums :
    Inscription : Août 2013
    Messages : 42
    Par défaut
    Bonjour,

    Si les codes sur 28 caractères commencent toujours par un % et ceux sur 13 caractères par un caractère alphanumérique, on peut faire aussi :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    SELECT Id, MIN(BarCode)
    FROM Table
    GROUP BY Id

  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
    Par défaut
    et sinon, comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    SELECT id
        ,COALESCE(MAX(CASE WHEN LEN(BarCode) = 13 THEN BarCode END), MAX(BarCode)) AS BarCode
    FROM LaTable
    GROUP BY Id

  5. #5
    Membre éprouvé
    Inscrit en
    Avril 2007
    Messages
    1 247
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 1 247
    Par défaut
    Bonjour à tous,
    Avant tout , merci de vous pencher sur mon problème
    escartefigue et III Jonathan III , vos réponse ne fonctionnent pas malheureusement
    je vais tester celle de aieeeuuuuu et je reviens vers vous

  6. #6
    Membre éprouvé
    Inscrit en
    Avril 2007
    Messages
    1 247
    Détails du profil
    Informations forums :
    Inscription : Avril 2007
    Messages : 1 247
    Par défaut
    Bonjour aieeeuuuuu
    Ta solution ne fonctionne pas.
    Pourrais tu me dire pourquoi tu selectionne le max du champ barcode ?

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

Discussions similaires

  1. Mise à jour d'un seul enregistrements parmi plusieurs identiques
    Par Christophe Charron dans le forum Développement
    Réponses: 2
    Dernier message: 06/09/2016, 10h55
  2. Réponses: 6
    Dernier message: 02/11/2007, 22h49
  3. Réponses: 6
    Dernier message: 19/09/2006, 18h55
  4. Réponses: 1
    Dernier message: 14/07/2006, 17h23
  5. Sélection d'enregistrement parmis plusieurs identiques
    Par monnoliv dans le forum Décisions SGBD
    Réponses: 2
    Dernier message: 24/09/2005, 15h32

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