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 :

SELECT de 100 row, par série de 25 d'un certain contenu d'un champ


Sujet :

Langage SQL

  1. #1
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2005
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2005
    Messages : 60
    Points : 28
    Points
    28
    Par défaut SELECT de 100 row, par série de 25 d'un certain contenu d'un champ
    Bonjour,

    Bon OK, le titre n'est pas très explicite, je m'explique:

    J'ai une table de x enregistrements (1 par jour depuis 10 ans)
    Chaque ROW contient un champs 'TYPE' avec la lettre A, B, C ou D, ainsi qu'un champ horodatage TIME_K.
    Je voudrais un SELECT des 100 dernières ROW enregistrées, mais avec les 25 derniers A, 25 derniers B, 25 dernierss C et 25 derniers D...le tout trié, les A en premier etc...

    Évidement, le champ 'TYPE' n'est pas déjà trié, contrairement au champ TIME_K qui correspond à un INSERT journalier.

    Je voudrais une seule requête. J'ai dejà fait 4 requête et ça fonctionne, mais c'est moche.

    Je n'ai strictement aucune idée...MERCI!!

  2. #2
    Rédacteur

    Avatar de SQLpro
    Homme Profil pro
    Expert bases de données / SQL / MS SQL Server / Postgresql
    Inscrit en
    Mai 2002
    Messages
    21 768
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Expert bases de données / SQL / MS SQL Server / Postgresql
    Secteur : Conseil

    Informations forums :
    Inscription : Mai 2002
    Messages : 21 768
    Points : 52 565
    Points
    52 565
    Billets dans le blog
    5
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    WITH 
    T AS
    (
    SELECT *, ROW_NUMBER() OVER(PARTITION BY "TYPE" ORDER BY TIME_K DESC) AS N
    FROM   MA_TABLE
    )
    SELECT *
    FROM   T
    WHERE  N <= 25
    Et apprenez le SQL :
    1) les fonctions de fenêtrage : https://sqlpro.developpez.com/articl...clause-window/
    2) les CTE : https://sqlpro.developpez.com/cours/...te-recursives/

    A +
    Frédéric Brouard - SQLpro - ARCHITECTE DE DONNÉES - expert SGBDR et langage SQL
    Le site sur les SGBD relationnels et le langage SQL: http://sqlpro.developpez.com/
    Blog SQL, SQL Server, SGBDR : http://blog.developpez.com/sqlpro
    Expert Microsoft SQL Server - M.V.P. (Most valuable Professional) MS Corp.
    Entreprise SQL SPOT : modélisation, conseils, audit, optimisation, formation...
    * * * * * Expertise SQL Server : http://mssqlserver.fr/ * * * * *

  3. #3
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2005
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2005
    Messages : 60
    Points : 28
    Points
    28
    Par défaut
    Oui, j'avais vu la doc, mais ce sont de requêtes très rare chez moi...

    Je regarde votre requête et vos liens. Merci.

  4. #4
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2005
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2005
    Messages : 60
    Points : 28
    Points
    28
    Par défaut
    En fait la requête n'extrait pas exactement le résultat escompté:

    Je cherche à avoir les 25 plus récents enregistrements avec la lettre A, suivi des 25 plus récents enregistrements avec la lettre B, suivi des 25 plus récents enregistrements avec la lettre C et suivi des 25 plus récents enregistrements avec la lettre D.

    Du style: AAAAAAAAAABBBBBBBBBBCCCCCCCCCDDDDDDDDDD le tout trié via l'horodatage.

  5. #5
    Modérateur
    Avatar de al1_24
    Homme Profil pro
    Retraité
    Inscrit en
    Mai 2002
    Messages
    9 080
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 63
    Localisation : France, Val de Marne (Île de France)

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

    Informations forums :
    Inscription : Mai 2002
    Messages : 9 080
    Points : 30 803
    Points
    30 803
    Par défaut
    Il suffit juste de rajouter la clause ORDER BY avec les colonnes qui vont bien
    Modérateur Langage SQL
    Règles du forum Langage SQL à lire par tous, N'hésitez pas à consulter les cours SQL
    N'oubliez pas le bouton et pensez aux balises
    [code]
    Si une réponse vous a aidé à résoudre votre problème, n'oubliez pas de voter pour elle en cliquant sur
    Aide-toi et le forum t'aidera : Un problème exposé sans mentionner les tentatives de résolution infructueuses peut laisser supposer que le posteur attend qu'on fasse son travail à sa place... et ne donne pas envie d'y répondre.

  6. #6
    Nouveau membre du Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Août 2005
    Messages
    60
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Aveyron (Midi Pyrénées)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2005
    Messages : 60
    Points : 28
    Points
    28
    Par défaut
    Super!!! Merci ;-)

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

Discussions similaires

  1. [MySQL] selection de produits commencant par 2 chiffres
    Par freija dans le forum Langage SQL
    Réponses: 7
    Dernier message: 04/08/2006, 10h34
  2. selection de boutons radios par défaut
    Par boss_gama dans le forum ASP
    Réponses: 5
    Dernier message: 12/07/2006, 08h45
  3. Imprimer des selections excel en pdf par VBA
    Par ouellet5 dans le forum Macros et VBA Excel
    Réponses: 4
    Dernier message: 07/12/2005, 17h29
  4. Réponses: 3
    Dernier message: 29/08/2005, 16h44
  5. Selection d'une version par produit
    Par LaNat dans le forum Langage SQL
    Réponses: 12
    Dernier message: 09/06/2005, 08h19

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