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

Langage SQL Discussion :

Enlever les répétitions de certains champs


Sujet :

Langage SQL

  1. #1
    Membre régulier
    Inscrit en
    Avril 2006
    Messages
    268
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 268
    Points : 101
    Points
    101
    Par défaut Enlever les répétitions de certains champs
    Bonjour,

    bon dsl ça risque d'être un poste inutile mais je ne sais pas trop comment chercher ce que je veux dans google. C'est un truc que j'ai fait 50 fois pendant mes études mais ça commence à dater lol.

    En fait j'ai une requête qui me renvoie :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    toto velo
    toto voiture
    toto chien
    toot chat
    et je voudrais que ça me donne :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    toto velo
           voiture
           chien
           chat
    Voila quelqu'un peut-il m'aider je ne pense pas que ça soit bien dur, j'ai tenté un GROUP BY mais ça ne fait pas ce que je veux.

  2. #2
    Membre éclairé Avatar de EIN-LESER
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2008
    Messages
    703
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 47
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Service public

    Informations forums :
    Inscription : Mai 2008
    Messages : 703
    Points : 778
    Points
    778
    Par défaut
    je sais que tu peux virer des lignes en doubles avec distinct mais il me semble que pour sa la ligne complete doit etre en double et sa la vire completement

  3. #3
    Membre régulier
    Inscrit en
    Avril 2006
    Messages
    268
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 268
    Points : 101
    Points
    101
    Par défaut
    Non justement je ne veux pas supprimer la ligne complète je veux juste éviter la répétition de toto.

  4. #4
    Membre émérite Avatar de lola06
    Femme Profil pro
    Consultante en Business Intelligence
    Inscrit en
    Avril 2007
    Messages
    1 316
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Consultante en Business Intelligence
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 316
    Points : 2 520
    Points
    2 520
    Par défaut
    Bonjour,

    il me semble que ce que tu veux faire s'apparente a de la cosmétique, ce qui n'est pas le but du SQL.

    Regarde les différentes discussions sur la cosmétiques, peut être que des solutions sont sorties.

    A+

  5. #5
    Membre régulier
    Inscrit en
    Avril 2006
    Messages
    268
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 268
    Points : 101
    Points
    101
    Par défaut
    Mouai je suis assez perplexe sur cette histoire de cosmétique alors que j'ai le très net souvenir de l'avoir fait plusieurs fois en cours de SQL, sauf que je ne me souviens plus comment le faire .

  6. #6
    Membre émérite Avatar de lola06
    Femme Profil pro
    Consultante en Business Intelligence
    Inscrit en
    Avril 2007
    Messages
    1 316
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 37
    Localisation : France, Hauts de Seine (Île de France)

    Informations professionnelles :
    Activité : Consultante en Business Intelligence
    Secteur : Service public

    Informations forums :
    Inscription : Avril 2007
    Messages : 1 316
    Points : 2 520
    Points
    2 520
    Par défaut
    Sinon tu peux faire en 2 requêtes :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    Select distinct nom
    From maTable
    nom
    ###
    toto
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    Select objet 
    from maTable 
    Where nom = "toto"
    objet
    ####
    voiture
    vélo
    chien
    chat

    Après montre nous la structure de la base de données, il y aurait peut être un moyen de la changer pour faire ce que tu veux...
    Mais a priori je ne pense pas que ce soit possible...

    A+

  7. #7
    Membre régulier
    Inscrit en
    Avril 2006
    Messages
    268
    Détails du profil
    Informations forums :
    Inscription : Avril 2006
    Messages : 268
    Points : 101
    Points
    101
    Par défaut
    Bon j'ai retrouvé un exemple : http://www.adp-gmbh.ch/ora/sqlplus/beautify.html

    Donc ça se fait avec le BREAK ON le petit détail c'est que c'est du SQL PLUS donc je l'ai dans l'os lol.

    Merci quand même pour vos réponses .

  8. #8
    Membre émérite Avatar de pacmann
    Homme Profil pro
    Consulté Oracle
    Inscrit en
    Juin 2004
    Messages
    1 626
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Consulté Oracle
    Secteur : Distribution

    Informations forums :
    Inscription : Juin 2004
    Messages : 1 626
    Points : 2 845
    Points
    2 845
    Par défaut
    Salut !
    Ton SGBD prend en charge les fonctions analytiques (genre SQL Server, ou Oracle que tu n'as pas...).

    Si oui, tu peux faire :

    1) tu attribues un classement par groupes de "nom" (il faut bien un tri, donc tu prends objet)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    SELECT nom, objet, row_number() over(partition by nom order by object) as Num
    FROM TaTable
    2) tu sur-requêtes ce truc pour n'afficher "nom" que quand l'indice est = 1

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT CASE Num WHEN 1 THEN nom ELSE ' ' END, objet 
    FROM 
    (
    SELECT nom, objet, rownum() over(partition by nom order by object) as Num
    FROM TaTable
    ) t
    ORDER BY nom, num
    Ca n'en reste pas moins de la cosmétique pour autant !
    (c'est peut être un prof de cosmétique qui t'avait appris ça à l'époque )

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 03/02/2012, 14h03
  2. Modifier les valeurs de certains champs d'une table
    Par Xorbane dans le forum Requêtes et SQL.
    Réponses: 6
    Dernier message: 22/10/2007, 22h10
  3. enlever les zéro dans un champs
    Par shirya dans le forum ASP.NET
    Réponses: 4
    Dernier message: 26/03/2007, 18h01
  4. enlever les espace sur un champ texte
    Par lazzeroni dans le forum MS SQL Server
    Réponses: 5
    Dernier message: 22/09/2006, 13h41
  5. Réponses: 23
    Dernier message: 05/09/2005, 17h23

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