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 :

Cherche requête pour trouver la valeur la plus longue en nombre de caractères


Sujet :

Langage SQL

  1. #1
    Membre régulier
    Inscrit en
    Février 2009
    Messages
    204
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 204
    Points : 123
    Points
    123
    Par défaut Cherche requête pour trouver la valeur la plus longue en nombre de caractères
    Bonjour,

    je cherche la requête qui me permet de trouver la valeur la plus longue en nombre de caractère.

    Pour être plus clair, voici une table t très simple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    id | nom_joueur | age_joueur | equipe_nationale
    --------------------------------------------------------------------
    1 | zidane | 26 | france
    2 | henry | 22 | france
    3 | ronaldo | 25 | brésil 
    4 | cesar | 23 | brésil
    Ce que je voudrais, c'est une requête qui me permet de trouver le nom le plus long et l'age minimum pour chaque équipe, càd que le résultat attendu de la requête doit être ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    zidane | 22 | france => car dans l'équipe de france, le nom le plus long est zidane, et l'age minimum est 22 (détenu par henry)
    ronaldo | 23 | brésil => car dans l'équipe du brésil, le nom le plus long est ronaldo, et l'age minimum est 23 (détenu par cesar)
    Pour l'instant, j'arrive seulement à trouver l'age minimum pour chaque équipe avec cette requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    select min(age_joueur) from t group by equipe_nationale
    Mais je n'arrive pas à trouver en plus le nom le plus long en nombre de caractères pour chaque équipe.

    Je sais que je dois utiliser max(char_length(nom_joueur)) qui retourne le nombre maximal de caractères du nom (mais pas le nom qui possède ce nombre maximal), mais je n'arrive pas à l'imbriquer dans la requête.

    Une idée ? Merci d'avance, cordialement.

  2. #2
    Expert confirmé
    Homme Profil pro
    Inscrit en
    Mai 2002
    Messages
    3 173
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Mai 2002
    Messages : 3 173
    Points : 5 345
    Points
    5 345
    Par défaut
    bonjour,

    quel est votre sgbd ?

  3. #3
    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

    Vous pouvez faire comme ceci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    WITH Tmp AS (
    	SELECT 
    		equipe_nationale,
    		nom_joueur,
    		MIN(age_joueur) OVER(PARTITION BY equipe_nationale) AgeMin,
    		MAX(char_length(nom_joueur)) OVER(PARTITION BY equipe_nationale) AS L
    	FROM LaTable
    	)
    SELECT equipe_nationale,nom_joueur,AgeMin
    FROM tmp
    WHERE L = char_length(nom_joueur)
    Mais qu'attendez vous comme résultat si plusieurs joueurs ont le nom le plus long ?

  4. #4
    Membre régulier
    Inscrit en
    Février 2009
    Messages
    204
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 204
    Points : 123
    Points
    123
    Par défaut
    Bonjour, et merci pour vos réponses rapide.

    Citation Envoyé par punkoff Voir le message
    bonjour,

    quel est votre sgbd ?
    => mon sgbd est mysql


    Citation Envoyé par aieuuuuuuuu
    Mais qu'attendez vous comme résultat si plusieurs joueurs ont le nom le plus long ?
    => si plusieurs joueurs ont le même nom, par exemple zidane (6 caractères) et thuram (6 caractères) qui font partie de la même équipe, et bien on en prend que 1 seul, n'importe lequel (dans ce cas un limit 0, 1 ne me dérange pas).
    Je ne sais pas si la requête que vous proposez est adaptable à mysql (mais c'est ma faute j'aurais du préciser mon sgbd).

    J'espère que ces éléments vous faciliteront.

  5. #5
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 950
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 950
    Points : 5 849
    Points
    5 849
    Par défaut
    Le plus simple et performant c'est cette requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    select t.equipe_nationale, t.nom_joueur, t2.min_age
      from (select equipe_nationale, max(char_length(nom_joueur)) as max_len, min(age_joueur) as min_age
              from t
             group by equipe_nationale) t2
       join t
         on t.equipe_nationale = t2.equipe_nationale 
        and char_length(t.nom_joueur) = t2.max_len
    Mais en cas d'égalité de longueur de nom, il y aura plusieurs lignes pour une même équipe (personnellement je trouve ça normal de les afficher mais bon)

    Sinon on peut passer par des requêtes corrélées mais mysql n'est pas très bon en requête corrélée... à tester :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    select distinct t.equipe_nationale,
           (select t2.nom_joueur 
              from t t2 
             where t2.equipe_nationale = t.equipe_nationale 
             order by char_length(t2.nom_joueur) desc, id
             limit 1) as nom_joueur,
            (select t3.age_joueur 
              from t t3 
             where t3.equipe_nationale = t.equipe_nationale 
             order by t3.age_joueur, id 
             limit 1) as age_joueur 
       from t
    Donc peut être plutôt en joignant la table à elle même 2 fois :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    select t.equipe_nationale, max(t2.nom_joueur), max(t3.age_joueur)
      from t
      left join t t2 on t2.equipe_nationale        = t.equipe_nationale
                    and char_length(t2.nom_joueur) > char_length(t.nom_joueur)
      left join t t3 on t3.equipe_nationale        = t.equipe_nationale
                    and t3.age_joueur              < t.age_joueur
     group by t.equipe_nationale

  6. #6
    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
    Citation Envoyé par skuatamad Voir le message
    Le plus simple et performant c'est cette requête :
    [...]
    Mais en cas d'égalité de longueur de nom, il y aura plusieurs lignes pour une même équipe
    En gardant cette requête, il suffit de regrouper et garder (arbitrairement) le min ou le max des nom des joueurs :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    SELECT t.equipe_nationale, MIN(t.nom_joueur), t2.min_age
      FROM (SELECT equipe_nationale, max(len(nom_joueur)) AS max_len, min(age_joueur) AS min_age
              FROM t
             GROUP BY equipe_nationale) t2
       JOIN t
         ON t.equipe_nationale = t2.equipe_nationale 
        AND len(t.nom_joueur) = t2.max_len
       GROUP BY t.equipe_nationale, t2.min_age

  7. #7
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 950
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 950
    Points : 5 849
    Points
    5 849
    Par défaut
    Citation Envoyé par aieeeuuuuu Voir le message
    En gardant cette requête, il suffit de regrouper et garder (arbitrairement) le min ou le max des nom des joueurs :
    Ah ben oui
    merci

  8. #8
    Membre régulier
    Inscrit en
    Février 2009
    Messages
    204
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 204
    Points : 123
    Points
    123
    Par défaut
    Merci à vous tous pour vos réponses, grâce à vos réponses, mon problème est résolu.

    J'ai même adapté votre solution à la version sans le "join" grâce à vous :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    SELECT t.nom_joueur, CHAR_LENGTH( t.nom_joueur ) AS length_nom_joueur, MIN( t.age_joueur ) , equipe_nationale
    FROM t, 
    (
    SELECT MAX( CHAR_LENGTH( nom_joueur ) ) AS max_length_nom_joueur
    FROM t
    GROUP BY equipe_nationale
    ) t2 
    WHERE CHAR_LENGTH( t.nom_joueur ) = t2.max_length_nom_joueur
    GROUP BY equipe_nationale
    Je vous envie beaucoup pour le bagage sql que vous avez, ça se voit que vous êtes des grands professionnels.

    Merci 1000 fois.

  9. #9
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 950
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 950
    Points : 5 849
    Points
    5 849
    Par défaut
    Attention vous avez fait un peu n'importe quoi, cette requête sur tout autre SGBDR que mysql renverrait une erreur.
    Utilisez la requête de aieeeuuuuu !

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

Discussions similaires

  1. Réponses: 6
    Dernier message: 09/02/2015, 10h54
  2. Réponses: 2
    Dernier message: 12/05/2014, 11h53
  3. requête pour "effacer" certaines valeurs ?
    Par kikidrome dans le forum Requêtes et SQL.
    Réponses: 24
    Dernier message: 27/02/2007, 16h35
  4. requête pour trouver un mot dans une phrase
    Par FRIGAUX dans le forum Requêtes et SQL.
    Réponses: 6
    Dernier message: 25/11/2006, 22h18
  5. [VBA-E]Methode pour trouver une valeur qui apparait plusieur fois
    Par Elstak dans le forum Macros et VBA Excel
    Réponses: 9
    Dernier message: 23/05/2006, 13h11

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