Précédent   Forum des professionnels en informatique > Bases de données > Oracle > SQL
SQL Forum d'entraide sur le SQL pour Oracle
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 31/03/2008, 16h34   #1
Modérateur
 
Avatar de al1_24
 
Homme Alain
Ingénieur d'études décisionnel
Inscription : mai 2002
Messages : 4 455
Détails du profil
Informations personnelles :
Nom : Homme Alain
Âge : 51
Localisation : France, Val de Marne (Île de France)

Informations professionnelles :
Activité : Ingénieur d'études décisionnel
Secteur : Conseil

Informations forums :
Inscription : mai 2002
Messages : 4 455
Points : 7 580
Points : 7 580
Par défaut Opérateur (+) = et jointure interne

Bonjour,

Je dois reprendre des requêtes Oracle et les passer en SQL normalisé.
Cela fait bien longtemps que je n'ai pas pratiqué les opérateurs hors norme d'Oracle.
J'ai retrouvé ces règles de base :
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
SELECT    *
FROM    TMP_A    A
    ,    TMP_B    B
WHERE    A.CLE = B.CLE
;
/* équivaut à */
SELECT    *
FROM    TMP_A    A
    INNER JOIN
        TMP_B    B
        ON    A.CLE = B.CLE
;
 
SELECT    *
FROM    TMP_A    A
    ,    TMP_B    B
WHERE    A.CLE (+) = B.CLE
;
/* équivaut à */
SELECT    *
FROM    TMP_A    A
    RIGHT JOIN
        TMP_B    B
        ON    A.CLE = B.CLE
;
 
SELECT    *
FROM    TMP_A    A
    ,    TMP_B    B
WHERE    A.CLE = B.CLE (+)
;
/* équivaut à */
SELECT    *
FROM    TMP_A    A
    LEFT JOIN
        TMP_B    B
        ON    A.CLE = B.CLE
;
Je suppose que :
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
 
SELECT    *
FROM    TMP_A    A
    ,    TMP_B    B
WHERE    A.CLE (+) = B.CLE
    AND    A.VAL (+) = 'X'
;
/* équivaut à */
SELECT    *
FROM    TMP_A    A
    RIGHT JOIN
        TMP_B    B
        ON    A.CLE = B.CLE
        AND    A.VAL = 'X'
;
Mais je me trouve face à ça :
Code :
1
2
3
4
5
6
7
 
SELECT    *
FROM    TMP_A    A
    ,    TMP_B    B
WHERE    A.CLE = B.CLE
    AND    A.VAL (+) = 'X'
;
Comment l'écririez vous avec jointure normalisée ?
__________________
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
al1_24 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/03/2008, 16h46   #2
McM
Expert Confirmé Sénior
 
Inscription : juillet 2003
Messages : 3 459
Détails du profil
Informations forums :
Inscription : juillet 2003
Messages : 3 459
Points : 4 226
Points : 4 226
INNER JOIN, le (+) ne sert à rien dans cette requete
__________________
More Code : More Bugs. Less Code : Less Bugs
McM est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 31/03/2008, 18h42   #3
Modérateur
 
Avatar de al1_24
 
Homme Alain
Ingénieur d'études décisionnel
Inscription : mai 2002
Messages : 4 455
Détails du profil
Informations personnelles :
Nom : Homme Alain
Âge : 51
Localisation : France, Val de Marne (Île de France)

Informations professionnelles :
Activité : Ingénieur d'études décisionnel
Secteur : Conseil

Informations forums :
Inscription : mai 2002
Messages : 4 455
Points : 7 580
Points : 7 580
C'est bien ce qui me semblait, mais je voulais être sûr de ne pas passer à côté d'un truc tordu
__________________
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
al1_24 est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 18h55.


 
 
 
 
Partenaires

Hébergement Web