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 :

[SQL] récupération deux date sur le même champ


Sujet :

SQL Oracle

  1. #1
    Membre du Club
    Inscrit en
    Février 2009
    Messages
    53
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 53
    Points : 44
    Points
    44
    Par défaut [SQL] récupération deux date sur le même champ
    Bonjour,


    J'ai deux tables :
    Demande : id, nom, sommaire, détail ...
    Realiser : id_demande, id_utilisateur, datereal, etat


    Je voudrais récupérer l id de la demande, l état (qui est refusé ou cloturer) de la réalisation, la date de la 1er réalisation des demande qui sont donc cloturer ou refusé

    Vu qu une demande peut avoir plusieurs réalisation, (saisie, transmise, prise en compte, terminer, refusé ...) je ne sais pas comment
    faire cette requête car dans un sens je restreins les demandes a celle qui sont refusée ou cloturer (les dernières réalisations) et dans un autre je voudrais
    la date de saisie (la 1er réalisation)

    J ai essayé plusieurs requête mais aucune ne marche,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    select d.id, r.etat, datereal datefin, d.sommaire, d.nom demadeur, a.datedeb
    from demande d, realiser r, (select min(datereal) datedeb from realiser where id_demande = d.id ) a
    where d.id= r.id_demande
    and LOWER(r.etat) in ('refusé','cloturer');
    Celle ci ne fonctionne pas car les vue synchronisé ça n'existe pas

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    select d.id, r.etat, MAX(datereal) datefin, d.sommaire, d.nom demadeur, MIN(datereal) datedeb
    from demande d, realiser r
    where d.id= r.id_demande
    and LOWER(r.etat) in ('refusé','cloturer')
    group by d.id, r.etat, d.sommaire, d.nom;
    Et celle ci me renvoie les même date (de fin)


    Je viens a me poser la question, si c'est possible ou pas de faire se que je demande en 1 requête ??

    de l'aide serais la bien venu

  2. #2
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 453
    Points : 18 387
    Points
    18 387
    Par défaut
    Oui c'est possible, mais vos explications sont plutôt confuses.
    Un petit jeu d'essai représentatif avec ce que vous en attendez serait le bienvenu.

  3. #3
    Membre du Club
    Inscrit en
    Février 2009
    Messages
    53
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 53
    Points : 44
    Points
    44
    Par défaut
    Voila un jeux, une demande avec plusieurs réalisation,

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    insert into utilisateur values
    (1,'Jean')
    insert into utilisateur values
    (2, 'service technique')
    insert into utilisateur values
    (3, 'Responsable')
     
    insert into demande values
    (1, 'jean','bureau cassé','le pied avant droid du bureau est cassé')
     
    insert into realiser values
    (1,1,'10/05/2010','saisie')
    insert into realiser values
    (1,1,'10/05/2010','Transfér au service technique')
    insert into realiser values
    (1,2,'11/05/2010','prise en compte')
    insert into realiser values
    (1,2,'12/05/2010','Terminer')
    insert into realiser values
    (1,3,'13/05/2010','Cloturer')
    Voila et j'aimerais que la requête me renvoi donc le resultat
    1 | 'cloturer' | 13/05/2010 | 'bureau cassé' | 'Jean' | 10/05/2010


    j'espère me faire comprendre avec se jeux de résultat

  4. #4
    Modérateur
    Avatar de Waldar
    Homme Profil pro
    Sr. Specialist Solutions Architect @Databricks
    Inscrit en
    Septembre 2008
    Messages
    8 453
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Sr. Specialist Solutions Architect @Databricks
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2008
    Messages : 8 453
    Points : 18 387
    Points
    18 387
    Par défaut
    Il faut rajouter une seconde fois la table realiser dans votre requête, par exemple comme ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
      select d.id, r.etat,
             max(r.datereal) as datefin,
             d.sommaire, d.nom as demandeur,
             min(r2.datereal) as datedeb
        from demande d
             inner join realiser r
               on r.id_demande = d.id 
             inner join realiser r2
               on r2.id_demande = d.id 
       where lower(r.etat) in ('refusé', 'cloturer')
    group by d.id, r.etat, d.sommaire, d.nom;
    Pour conserver l'idée de votre première syntaxe, il aurait fallu l'écrire ainsi :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    with minreal as
    (
      select id_demande, min(datereal) as datedeb
        from realiser
    group by id_demande
    )
      select d.id, r.etat,
             max(r.datereal) as datefin,
             d.sommaire, d.nom as demandeur,
             mr.datedeb as datedeb
        from demande d
             inner join realiser r
               on r.id_demande = d.id 
             inner join minreal mr
               on mr.id_demande = d.id 
       where lower(r.etat) in ('refusé', 'cloturer')
    group by d.id, r.etat, d.sommaire, d.nom, mr.datedeb;

  5. #5
    Expert éminent sénior Avatar de mnitu
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Octobre 2007
    Messages
    5 611
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2007
    Messages : 5 611
    Points : 11 252
    Points
    11 252
    Par défaut
    Une requête scalaire devrait faire l'affaire aussi.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
     
    SELECT d.id, r.etat, datereal datefin, d.sommaire, d.nom demadeur, 
           (SELECT min(datereal) datedeb 
              FROM realiser 
             WHERE id_demande = d.id ) datedeb
      FROM demande d, realiser r 
     WHERE d.id= r.id_demande
       AND LOWER(r.etat) IN ('refusé','cloturer')

  6. #6
    Membre du Club
    Inscrit en
    Février 2009
    Messages
    53
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 53
    Points : 44
    Points
    44
    Par défaut
    Merci pour ces réponses vous m'avez bien aidé,

    ça m'a permis d'apprendre quelques truck comme la requête scalaire ou mettre WITH ... AS pour déclarer une vue avant je ne connaissais pas.

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

Discussions similaires

  1. [SQL Serveur 2005] Deux index sur le même champ
    Par Griswold dans le forum Développement
    Réponses: 3
    Dernier message: 28/06/2010, 18h41
  2. Réponses: 2
    Dernier message: 16/07/2008, 14h21
  3. comparer deux dates sur sql
    Par Tenro dans le forum Requêtes et SQL.
    Réponses: 3
    Dernier message: 07/05/2006, 17h19
  4. Réponses: 6
    Dernier message: 28/09/2005, 10h24
  5. installation de deux serveurs sur une même machine
    Par desdak dans le forum Installation
    Réponses: 1
    Dernier message: 29/06/2005, 23h09

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