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 :

Recherche d'une valeur d'une autre table [10g]


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Février 2019
    Messages
    179
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Ressources humaines

    Informations forums :
    Inscription : Février 2019
    Messages : 179
    Par défaut Recherche d'une valeur d'une autre table
    Bonjour,

    Dans la requête ci-dessous, je compte le nombre de personne sur une date, en fonction d'un motif et d'une heure. J'utilise trois table avec des jointures
    Je souhaiterais obtenir dans une deuxième colonne le même nombre en le conditionnant à un critère d'une quatrième table.je voudrais compter le nombre de motif "PRESENT" si une des valeurs dans la quatrième table est égal à "CONDUCTEUR".
    Les correspondances avec la quatrième tables sont : T1.matri = T4.Matri et T4.MATRI = T2.matri
    Est-ce possible ?
    Merci pour vos retours.
    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
    SELECT T1.dat,
    round(sum (
    CASE 
    WHEN T1.MOTIF in ('PRESENT') 
    and  T1.HRAFIN >= '480' AND T1.HRADEB <= '1200'  then (1200- 480)/60/12
    else 0
    end),0) as NOMBRE
    from T2
     
    FULL OUTER JOIN T1 on T2.MATRI = T1.MATRI  
    FULL OUTER JOIN T3 on T1.MOTIF = T3.MOTIF
    WHERE  T1.DAT = '25/09/2019'
     
    GROUP BY T1.DAT
    ORDER BY T1.DAT

  2. #2
    Membre confirmé
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Février 2019
    Messages
    179
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Ressources humaines

    Informations forums :
    Inscription : Février 2019
    Messages : 179
    Par défaut
    Bonjour,

    Est-ce possible de réaliser de joindre une quatrième table ?

    Merci pour vos retours.

  3. #3
    Membre très actif
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Août 2014
    Messages
    261
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 32
    Localisation : France, Ille et Vilaine (Bretagne)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Août 2014
    Messages : 261
    Par défaut
    Bonjour bonjour,

    En soit, tout est possible. Il faut voir maintenant combien vous avez de lignes dans vos tables et de si les performances sont déjà ok dans la première requête.
    (Dans la première requête d'ailleurs soit votre "order by" ne sert pas soit votre "T1.dat" est "supérieur ou égal" à une date et non "égal à" une date, non ?)

    De plus, quel est votre niveau en SQL ? Si on parle de la notion de CTE, cela va-t-il vous parler ?

  4. #4
    Membre confirmé
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Février 2019
    Messages
    179
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Ressources humaines

    Informations forums :
    Inscription : Février 2019
    Messages : 179
    Par défaut
    Bonjour,

    Dans l'exemple j'ai mis une date, mais je fais la recherche sous pour plusieurs dates avec ce code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    Extract(Month from T1.dat) in ('09','10'
    Ca qui explique le order By.
    Les performances sont OK, 61 lignes en 1,41 secondes.

    Par contre je ne connais pas la notion de CTE.

    Merci pour votre aide.

  5. #5
    Membre confirmé
    Homme Profil pro
    Ressources humaines
    Inscrit en
    Février 2019
    Messages
    179
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Doubs (Franche Comté)

    Informations professionnelles :
    Activité : Ressources humaines

    Informations forums :
    Inscription : Février 2019
    Messages : 179
    Par défaut
    Bonjour,

    j'ai regardé du côté des CTE ( common table expression), mais je ne sais pas comment faire.

    Merci pour votre aide

  6. #6
    Modérateur
    Avatar de escartefigue
    Homme Profil pro
    bourreau
    Inscrit en
    Mars 2010
    Messages
    10 637
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loir et Cher (Centre)

    Informations professionnelles :
    Activité : bourreau
    Secteur : Finance

    Informations forums :
    Inscription : Mars 2010
    Messages : 10 637
    Billets dans le blog
    10
    Par défaut
    Bonjour,

    Vous vous compliquez la vie inutilement :
    - pourquoi faire 2 jointures OUTER sur les tables T2 et T3 dont vous n'utilisez aucune colonne
    - pourquoi mettre une restriction (WHERE) sur une colonne d'une table OUTER, ce qui transforme implicitement la jointure en INNER JOIN

    Sinon, une CTE c'est une table dérivée dont la construction est décrite en amont de la requête principale (plutôt que de faire une sous requête dans la requête principale, l'écriture est plus simple et la mise au point facilitée)

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

Discussions similaires

  1. Champ alimenté par une recherche d'une autre table
    Par garbit dans le forum Modélisation
    Réponses: 5
    Dernier message: 03/04/2013, 09h04
  2. rechercher la valeur d'un champs dans les champs d'une autre table
    Par aloe-vera dans le forum Développement de jobs
    Réponses: 4
    Dernier message: 02/08/2012, 14h53
  3. Faire une recherche sur une autre table?
    Par csilas dans le forum VB 6 et antérieur
    Réponses: 2
    Dernier message: 04/02/2010, 08h45
  4. Réponses: 1
    Dernier message: 23/10/2009, 18h49
  5. Rechercher une valeur dans un autre table
    Par zangel dans le forum Access
    Réponses: 4
    Dernier message: 10/09/2008, 01h48

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