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

MS SQL Server Discussion :

Exercice jointure sql


Sujet :

MS SQL Server

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2013
    Messages
    35
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2013
    Messages : 35
    Par défaut Exercice jointure sql
    * Bonjour, *

    Afficher le nom et la date d’engagement des employés arrivés après BLAKE

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    select C.ename, c.hiredate
    from emp b inner join emp c
    on b.ename = 'BLAKE' and c.hiredate > b.hiredate
    Je comprends que c'est un "self join", c'est la ligne avec le ON que je ne saisis pas.
    Quelqu'un pourrait m'en dire plus svp?

    Merciiiiiiii

  2. #2
    Membre éclairé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Octobre 2008
    Messages
    699
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : Boutique - Magasin

    Informations forums :
    Inscription : Octobre 2008
    Messages : 699
    Par défaut
    Citation Envoyé par EleanoreDes Voir le message
    Afficher le nom et la date d’engagement des employés arrivés après BLAKE


    select C.ename, c.hiredate
    from emp b inner join emp c
    on b.ename = 'BLAKE' and c.hiredate > b.hiredate

    Je comprends que c'est un "self join", c'est la ligne avec le ON que je ne saisis pas.
    Quelqu'un pourrait m'en dire plus svp?
    Merciiiiiiii
    Remplace "ON" par "quand" et lit a haute voix

  3. #3
    Candidat au Club
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Décembre 2013
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2013
    Messages : 4
    Par défaut
    Par défaut, un JOIN est implicitement un CROSS JOIN, qui retourne le produit cartésien des deux tables, soit un résultat pour chaque couple possible de lignes. Dans le cas d'un self-join d'une table de 1.000 lignes, cela donnerait 1.000.000 de résultats. La clause ON sert à filtrer ce produit cartésien.

    Ici, la compréhension est un peu difficile car le self-join n'est pas strictement nécessaire. Il sert à obtenir le résultat en une seule requête, alors qu'il en faudrait deux autrement : une première pour récupérer la date d'engagement de Blake, et une seconde pour récupérer les noms et les dates d'engagement des employés arrivés après lui.

    PS : Evidemment, tout moteur de base de données élémentaire repère la présence de la clause ON avant de créer le produit cartésien et optimise l'exécution de la requête. Mais dans la théorie, tout se passe "comme si".

  4. #4
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2013
    Messages
    35
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2013
    Messages : 35
    Par défaut Merci beaucoup:) J'ai une autre question svp
    Afficher le numéro et le nom de tous les employés qui travaille dans un département qui contient au moins une personne dont le nom possède la lettre T


    structure de la table
    colonne
    empno - ename - job - deptno

  5. #5
    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
    Par défaut
    Bonjour,

    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
    12
    13
    14
     
    WITH Tmp AS (
    	SELECT 
    		empno, 
    		ename, 
    		MAX(CASE WHEN ename LIKE '%T%' THEN 1 END) 
    			OVER(PARTITION BY deptno) AS DepOk
    	FROM employe
    )
    SELECT 
    	empno, 
    	ename
    FROM Tmp
    WHERE DepOk = 1

  6. #6
    Membre averti
    Profil pro
    Inscrit en
    Décembre 2013
    Messages
    35
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Décembre 2013
    Messages : 35
    Par défaut
    merci, mais c'est trop compliqué pour moi Trop de notion qui ne sont pas dans mes cours.

    C'est le chapitre sur les sous requetes
    j'ai pas vu le
    max
    tmp
    partition
    then
    over

    J'ai vu group by, having, les sous requetes, et les selection de base

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    SELECT a.ename, a.sal, a.deptno, b.salavg
    FROM emp a INNER JOIN
    (SELECT deptno, avg(sal) AS salavg
    FROM emp
    GROUP BY deptno) b
    ON a.deptno = b.deptno
    WHERE a.sal > b.salavg
    je dois me débrouiller avec ça

Discussions similaires

  1. [SQL] problème de variable tableau PHP contenant les données d'une jointure SQL
    Par Schpountz42 dans le forum PHP & Base de données
    Réponses: 1
    Dernier message: 09/02/2007, 05h59
  2. [MS Query] neophyte demande aide sur jointures SQL
    Par thorgal972 dans le forum Langage SQL
    Réponses: 19
    Dernier message: 27/11/2006, 17h13
  3. [SQL] PB : Jointure SQL ne fonctionne pas..
    Par guillaumeIOB dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 13/09/2006, 14h03
  4. Réponses: 1
    Dernier message: 28/07/2006, 03h57
  5. Réponses: 4
    Dernier message: 11/10/2005, 10h17

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