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

SQL Oracle Discussion :

Avant dernier et dernier résultat dans 1 entrée


Sujet :

SQL Oracle

  1. #1
    Nouveau membre du Club
    Inscrit en
    Juin 2008
    Messages
    95
    Détails du profil
    Informations forums :
    Inscription : Juin 2008
    Messages : 95
    Points : 34
    Points
    34
    Par défaut Avant dernier et dernier résultat dans 1 entrée
    Bonjour, j'ai un petit soucis en SQL je ne sais pas comment ramener les deux premiers résultat d'une requète.

    Soit la table RESERVATION composé de : RESERV_ID| DATE_RESERV | NBPERS

    Lorsque j'interroge ma table j'ai deux résultat :

    1 | 30/01/2011 | 3
    2 | 28/01/2011 | 2

    Je cherche la requête pour n'avoir qu'un seul résultat retourné et composé des deux entrées. Malheureusement avec le code suivant je retourne :
    2 | 28/01/2011 | 2 | 2 | 28/01/2011 | 2

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
     
    SELECT * FROM(
       SELECT * FROM RESERVATION WHERE rownum<=1 ORDER BY DATE_RESERV DESC) r1
       JOIN 
       (SELECT * FROM RESERVATION WHERE rownum<=1 ORDER BY DATE_RESERV ASC) r2
     
    ON r1.RESERV_ID = r2.RESERV_ID)
    Il peut y aussi y avoir plus de deux entrées dans cette table, à chaque fois il faut que je retourne la dernière et l'avant-dernière réservation.

    Pouvez-vous m'aider SVP ? Merci d'avance !

    ps : je sais c'est pas très beau comme code mais j'ai pas trouvé mieux, cela dit je reste ouvert aux propositions !

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

    Informations forums :
    Inscription : Août 2008
    Messages : 2 947
    Points : 5 846
    Points
    5 846
    Par défaut
    Première erreur dans :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    WHERE rownum<=1 ORDER BY DATE_RESERV DESC
    rownum est évalué avant le ORDER BY, donc il faut toujours trier d'abord dans une sous requête avant de filtrer avec rownum.

    Après quel est l'intérêt d'avoir les résultats sur 1 seule ligne ? c'est contre performant et il est préférable que ce soit le langage client (java,php,pl/sql....) qui pivote les lignes.

    Si tu n'as vraiment pas le choix tu peux utiliser le code suivant :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    select 
      max(case when t2.rn = 1 then t2.RESERV_ID end) as RESERV_ID_1,
      max(case when t2.rn = 1 then t2.DATE_RESERV end) as DATE_RESERV_1,
      max(case when t2.rn = 1 then t2.NBPERS end) as NBPERS_1,
      max(case when t2.rn = 2 then t2.RESERV_ID end) as RESERV_ID_2,
      max(case when t2.rn = 2 then t2.DATE_RESERV end) as DATE_RESERV_2,
      max(case when t2.rn = 2 then t2.NBPERS end) as NBPERS_2
    from 
      (select t.*, row_number() over (order by date_reserv desc) as rn from t) t2
    where t2.rn <= 2

  3. #3
    Nouveau membre du Club
    Inscrit en
    Juin 2008
    Messages
    95
    Détails du profil
    Informations forums :
    Inscription : Juin 2008
    Messages : 95
    Points : 34
    Points
    34
    Par défaut
    Bonjour Skuatamad et merci pour cette réponse, j'ai finalement réussi à résoudre mon problème.

    En fait j'utilise Jasper iReport pour créer un document et j'avais besoin de la dernière / avant-dernière entrée pour faire mes réservations. Malheureusement comme je connais mal iReport, je ne savais pas comment afficher deux entrées, donc j'ai décidé de les concaténer !

    Un peu bourrin comme solution mais quand on est pris par le temps...

    Merci beaucoup de ton aide !

Discussions similaires

  1. Réponses: 5
    Dernier message: 07/03/2008, 11h44
  2. [dernier element conteneur] insertion dans vecteur
    Par ZaaN dans le forum SL & STL
    Réponses: 1
    Dernier message: 02/08/2007, 11h37
  3. Derniere evolution flagage doublons dans Recordset
    Par ALEXM dans le forum VBA Access
    Réponses: 8
    Dernier message: 16/05/2007, 11h11
  4. Réponses: 2
    Dernier message: 16/12/2006, 12h34
  5. Réponses: 7
    Dernier message: 28/06/2006, 13h31

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