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 :

Inner join et nom de colonne dupliqué


Sujet :

SQL Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre Expert
    Avatar de Emmanuel Lecoester
    Profil pro
    Inscrit en
    Février 2003
    Messages
    1 493
    Détails du profil
    Informations personnelles :
    Âge : 49
    Localisation : France, Nord (Nord Pas de Calais)

    Informations forums :
    Inscription : Février 2003
    Messages : 1 493
    Par défaut Inner join et nom de colonne dupliqué
    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
     
     drop table toto3
     
     create table toto1 (l1 number , i1 number) ;
     
      insert into toto1 values (null, 1) ;
     
      create table toto2 (l1 number , i2 number) ;
     
      insert into toto2 values  (20, 1) ;
     
      create table toto3 (l3 number , i3 number) ;
     
      insert into toto3  values(30, 1) ;
     
      select l1 
      from toto3 
      inner join toto1 on toto1.i1= toto3.i3  
      inner join toto2 on toto1.i1= toto2.i2
    Qui peut me dire ce qui cloche dans la selection finale ? (c'est une boutade je sais quoi mais je ne sais pas l'expliquer )

  2. #2
    McM
    McM est déconnecté
    Expert confirmé

    Homme Profil pro
    Développeur Oracle
    Inscrit en
    Juillet 2003
    Messages
    4 580
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Développeur Oracle

    Informations forums :
    Inscription : Juillet 2003
    Messages : 4 580
    Billets dans le blog
    4
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    CREATE TABLE toto1 (l1 number , i1 number) ;
     CREATE TABLE toto2 (l1 number , i2 number) ;
    Toto2 contient aussi la colonne l1

    Donc oracle ne sait pas de laquelle tu parles.

    Edit : Rappelons que ta requête est équivalente à
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT l1 
    FROM  toto1, toto2, toto3
    WHERE toto1.i1= toto3.i3  
    AND toto1.i1= toto2.i2

  3. #3
    Expert confirmé 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
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    SQL> SELECT toto1.l1, toto2.l1, toto3.l3
      2    FROM toto3
      3    INNER JOIN toto1 ON toto1.i1= toto3.i3
      4    INNER JOIN toto2 ON toto1.i1= toto2.i2
      5  ;
     
            L1         L1         L3
    ---------- ---------- ----------
                       20         30

  4. #4
    Membre chevronné Avatar de chrifo
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    444
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 444
    Par défaut
    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
     
    SQL> SELECT l1 
      2    FROM toto3 
      3    INNER JOIN toto1 ON toto1.i1= toto3.i3 
      4    INNER JOIN toto2 ON toto1.i1= toto2.i2;
     
    aucune ligne sélectionnée
     
    SQL>   
    SQL> SELECT l1
      2    FROM  toto1, toto2, toto3
      3    WHERE toto1.i1= toto3.i3  
      4    AND toto1.i1= toto2.i2;
    SELECT l1
           *
    ERREUR à la ligne 1 :
    ORA-00918: Définition de colonne ambigu
     
     
    SQL>
    Je crois que la question porte plutôt la dessus, je n'avais jamais remarqué cette différence de résultat liée à la syntaxe, et la réponse m'intéresse également ...

    Désolé :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    SQL> SELECT version FROM v$instance;
     
    VERSION
    -----------------
    9.2.0.1.0

Discussions similaires

  1. Dupliquer des tables en changeant le nom des colonnes
    Par Tristan Zwingelstein dans le forum SQL Procédural
    Réponses: 4
    Dernier message: 23/03/2012, 15h11
  2. [JTable] les noms des colonnes de s'affichent pas
    Par macben dans le forum Composants
    Réponses: 6
    Dernier message: 25/04/2008, 11h03
  3. Mysql Inner join
    Par ..:: Atchoum ::.. dans le forum Requêtes
    Réponses: 3
    Dernier message: 25/10/2007, 12h21
  4. Erreur lors d'une requete INNER JOIN
    Par k-lendos dans le forum Langage SQL
    Réponses: 2
    Dernier message: 17/03/2004, 15h09
  5. Inner Join & Select
    Par bakaneko dans le forum Langage SQL
    Réponses: 7
    Dernier message: 10/02/2004, 10h48

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