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 :

[SQL Server2008] Criteres de classement


Sujet :

Développement SQL Server

  1. #1
    Membre chevronné
    Inscrit en
    Mai 2006
    Messages
    1 364
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 1 364
    Points : 1 984
    Points
    1 984
    Par défaut [SQL Server2008] Criteres de classement
    Bonjour,

    Je cherche à obtenir d'une table les enregistrements par type mais selon certains criteres.

    Un exemple valant mieux que mille mots, j'ai une table :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    ID          MONTYPE       ETAT         NUM
    1           1               0              1
    2           1               1              2
    3           1               1              3
    4           2               1              1
    5           2               0              2
    Sachant que le couple (MONTYPE, NUM) est unique, je cherche à obtenir tous les enregistrements classés par MONTYPE/NUM tant que l'etat n'est pas 1.

    Dans mon exemple, ca revient à obtenir :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    ID          MONTYPE       ETAT         NUM
    1           1               0              1
    2           1               1              2
    4           2               1              1
    Je pense pouvoir reussir en passant par une table temporaire mais je viens vers vous pour savoir si quelqu'un n'aurait pas une solution plus simple (à coup de RANK, ROW_NUMBER ou autre)...

    Merci

  2. #2
    Membre expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Points : 3 173
    Points
    3 173
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    SELECT T1.ID,
           T1.MONTYPE,
           T1.ETAT,
           T1.NUM
     FROM TABLE T1
    WHERE NOT EXISTS(SELECT *
                                FROM TABLE T2
                                WHERE T2.MONTYPE=T1.MONTYPE
                                  AND T2.NUM=T1.NUM 
                                  AND T2.ETAT=1
                                  AND T2.ID<T1.ID)
    ORDER BY T1.MONTYPE,T1.NUM
    Prendre conscience, c'est transformer le voile qui recouvre la lumière en miroir.
    MCTS Database Development
    MCTS Database Administration

  3. #3
    Membre chevronné
    Inscrit en
    Mai 2006
    Messages
    1 364
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 1 364
    Points : 1 984
    Points
    1 984
    Par défaut
    Merci pour ta réponse. Malheureusement, j'avais pensé à ce genre de requete mais ca m'oblige a passer par une table intermediaire (la table que j'ai présenté est en fait issue d'une requete).

    Il n'y a pas une methode plus simple ? Sinon, tant pis, je passerais par une variable table...

  4. #4
    Membre expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Points : 3 173
    Points
    3 173
    Par défaut
    On peut également passer par ROWINDEX...

    Postez l'intégralité de la requête...

    Si c'est un problème de lisibilité vous pouvez également pensez à créer des vues...
    Prendre conscience, c'est transformer le voile qui recouvre la lumière en miroir.
    MCTS Database Development
    MCTS Database Administration

  5. #5
    Membre chevronné
    Inscrit en
    Mai 2006
    Messages
    1 364
    Détails du profil
    Informations forums :
    Inscription : Mai 2006
    Messages : 1 364
    Points : 1 984
    Points
    1 984
    Par défaut
    Oui, c'est un probleme de lisibilité. La requete en elle meme n'est pas compliquée mais un peu imposante. Et si je dois la faire 2 fois, elle va devenir franchement illisible. C'est vrai, je pourrais utiliser une vue. Mais autant passer par une table temporaire dans ce cas (c'est moins les performances que la lisibilité qui m'interesse).

    Merci

  6. #6
    Membre expert Avatar de iberserk
    Homme Profil pro
    Architecte de base de données
    Inscrit en
    Novembre 2004
    Messages
    1 795
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Architecte de base de données
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Novembre 2004
    Messages : 1 795
    Points : 3 173
    Points
    3 173
    Par défaut
    Oui, c'est un probleme de lisibilité. La requete en elle meme n'est pas compliquée mais un peu imposante. Et si je dois la faire 2 fois, elle va devenir franchement illisible. C'est vrai, je pourrais utiliser une vue. Mais autant passer par une table temporaire dans ce cas (c'est moins les performances que la lisibilité qui m'interesse)
    Façon de voir les choses...
    Prendre conscience, c'est transformer le voile qui recouvre la lumière en miroir.
    MCTS Database Development
    MCTS Database Administration

  7. #7
    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
    Effectivement, en postant le vrai modele, et eventuellement la requete que vous avez deja faite, ce serait plus simple

    Sinon, pour votre problème de factorisation de code, si vous ne pouvez/voulez pas passer par une vue, pensez aux expression de table commune :

    Code SQL : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     
    ;WITH tmp AS (
    	[votre requete]
    )
    SELECT [MesColonnes]
    FROM tmp t1
    INNER JOIN tmp t2 ON [MaJointure]
    WHERE EXISTS ( 
    	SELECT *
    	FROM tmp t3
    )

Discussions similaires

  1. [SQL Server] problème de classement, calcul d'un rang
    Par lepeule dans le forum Langage SQL
    Réponses: 12
    Dernier message: 22/10/2019, 10h31
  2. Réponses: 1
    Dernier message: 14/08/2009, 08h23
  3. requete SQL avec regroupement et classement par ordre croissant
    Par adelsunwind dans le forum Requêtes et SQL.
    Réponses: 1
    Dernier message: 31/03/2009, 16h01
  4. [SQL] Elaboration d'un classement
    Par Angelik dans le forum PHP & Base de données
    Réponses: 10
    Dernier message: 23/08/2006, 00h49
  5. requete sql pour faire un classement
    Par beezee dans le forum Langage SQL
    Réponses: 2
    Dernier message: 04/03/2006, 13h03

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