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 :

Accéder à un synonyme public ayant le même nom qu'un objet


Sujet :

SQL Oracle

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    84
    Détails du profil
    Informations personnelles :
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Novembre 2009
    Messages : 84
    Points : 80
    Points
    80
    Par défaut Accéder à un synonyme public ayant le même nom qu'un objet
    Bonjour,

    Je me pose une question qui est la suivante :

    Nous somme dans un schema 'toto' par exemple, et cet utilisateur possède un table 'produits'. Cet utilisateur possède le rôle DBA.

    Nous créons un synonyme public 'produits' qui pointe vers la table 'magasin.produits' par exemple.

    À partir du schéma 'toto', comment utiliser le synonyme public 'produits' sachant qu'on possède déjà un object (ici une table) 'produits' ?

    J'ai tenté de préfixer le synonyme par public => public.produits lors d'un SELECT, mais j'ai une erreur ORA-00903: nom de table non valide.

    Une idée ?


    Merci d'avance.

  2. #2
    Membre régulier
    Inscrit en
    Décembre 2010
    Messages
    211
    Détails du profil
    Informations forums :
    Inscription : Décembre 2010
    Messages : 211
    Points : 102
    Points
    102
    Par défaut
    Deux objets ayant le même nom dans le même schéma ne peuvent cooexister.

    Donc dans ton schéma toto, soit tu as la table, soit le synonym 'PRODUITS'.

  3. #3
    Expert confirmé
    Profil pro
    Inscrit en
    Août 2008
    Messages
    2 950
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2008
    Messages : 2 950
    Points : 5 849
    Points
    5 849

  4. #4
    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

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Novembre 2009
    Messages
    84
    Détails du profil
    Informations personnelles :
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Novembre 2009
    Messages : 84
    Points : 80
    Points
    80
    Par défaut
    Citation Envoyé par AbouZaid Voir le message
    Deux objets ayant le même nom dans le même schéma ne peuvent cooexister.

    Donc dans ton schéma toto, soit tu as la table, soit le synonym 'PRODUITS'.
    Oui ça je sais bien, c'est pour ça que j'ai précisé que je créais un synonyme public, du coup ça n'appartient pas au même schéma.

    Donc pour résumer, si on a une table dans le schéma qui porte le même nom qu'un synonyme public, on ne pourra pas accéder à ce synonyme public... et on sera obligé de passer par schema.nom_table ?

  6. #6
    Membre régulier
    Inscrit en
    Décembre 2010
    Messages
    211
    Détails du profil
    Informations forums :
    Inscription : Décembre 2010
    Messages : 211
    Points : 102
    Points
    102
    Par défaut
    je n'ai pas essayé, mais ce qui est sur, c'est que les objets ont un identifiant unique.

  7. #7
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 461
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 461
    Points : 8 080
    Points
    8 080
    Par défaut
    Citation Envoyé par AbouZaid Voir le message
    Deux objets ayant le même nom dans le même schéma ne peuvent cooexister.
    C'est un peu rapide comme affirmation !
    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
    SQL> create table test(a int);
     
    Table creee.
     
    SQL> create index test on test(a);
     
    Index cree.
     
    SQL> select object_name, object_type from user_objects 
    where object_name='TEST';
     
     
    OBJECT_NAME     OBJECT_TYPE
    --------------- -------------------
    TEST            TABLE
    TEST            INDEX

  8. #8
    Membre régulier
    Inscrit en
    Décembre 2010
    Messages
    211
    Détails du profil
    Informations forums :
    Inscription : Décembre 2010
    Messages : 211
    Points : 102
    Points
    102
    Par défaut
    Vous avez raison, j'ai oublié de mentionner 'Objet De même type'

Discussions similaires

  1. Réponses: 2
    Dernier message: 03/07/2008, 12h09
  2. Stocker des tables ayant le même nom
    Par caroleo63 dans le forum Alimentation
    Réponses: 5
    Dernier message: 20/06/2008, 22h15
  3. Charger 2 dlls ayant le même nom
    Par kurtisnotdead dans le forum Framework .NET
    Réponses: 4
    Dernier message: 14/05/2008, 14h40
  4. Controller CheckBoxes ayant le même nom.
    Par JFKen dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 29/08/2006, 11h19
  5. Obtenir les enregistrements ayant le même nom et prénom
    Par llc123 dans le forum MS SQL Server
    Réponses: 4
    Dernier message: 11/07/2006, 16h47

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