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

PL/SQL Oracle Discussion :

Appel de synonyme dans une procédure


Sujet :

PL/SQL Oracle

  1. #1
    Candidat au Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2012
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Finance

    Informations forums :
    Inscription : Février 2012
    Messages : 4
    Points : 3
    Points
    3
    Par défaut Appel de synonyme dans une procédure
    Bonjour bonjour,

    Je vous expose mon problème :
    - je travaille sur 2 schémas, disons SCH_1 et SCH_2
    - une table TAB_A existe sur le schéma SCH2
    - un synonyme TAB_A est créé avec un GRANT SELECT, UPDATE, INSERT, DELETE pour le schéma SCH1
    - le synonym TAB_A est visible sous le schéma SCH_1 dans la table USER_SYNONYMS
    - Connecté sous le schéma SCH_1 je peux exécuter la requête suivante :
    DELETE FROM TAB_A;
    - Par contre si cette requête se trouve dans une procedure d'un package, à la compilation du package sur SCH_1 j'obtient l'erreur suivante :
    PL/SQL: ORA-00942: Table ou vue inexistante

    Le synonym est-il mal déclaré?
    Quelqu'un peut-il m'aider à résoudre ce problème capilotracté svp.

  2. #2
    Candidat au Club
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Février 2012
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : Finance

    Informations forums :
    Inscription : Février 2012
    Messages : 4
    Points : 3
    Points
    3
    Par défaut
    Problème résolu,
    Le grant était fait sur un role associé au schéma.
    Si le grant est fait directement sur le schéma, il n'y a plus d'erreur.

  3. #3
    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
    Par défaut
    Vous devez nous montrer ce que vous faite, comme dans l'exemple qui suit
    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
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
     
    C:\Documents and Settings\mnitu>sqlplus mni/mni@xe
     
    SQL*Plus: Release 11.2.0.2.0 Production on Mar. Juin 12 14:56:13 2012
     
    Copyright (c) 1982, 2010, Oracle.  All rights reserved.
     
     
    Connected to:
    Oracle Database 11g Express Edition Release 11.2.0.2.0 - Production
     
    SQL> create user sch1 identified by sch1;
     
    User created.
     
    SQL> create user sch2 identified by sch2;
     
    User created.
     
    SQL> grant resource, connect to sch1;
     
    Grant succeeded.
     
    SQL> grant resource, connect to sch2;
     
    Grant succeeded.
     
    SQL> grant create synonym to sch1;
     
    Grant succeeded.
     
    SQL> connect sch2/sch2
    Connected.
    SQL> create table tab_a(col int);
     
    Table created.
     
    SQL> grant select, insert, delete, update on tab_a to sch1;
     
    Grant succeeded.
     
    SQL> connect sch1/sch1
    Connected.
    SQL> create synonym tab_a for sch2.tab_a;
     
    Synonym created.
     
    SQL> select count(*) from tab_a;
     
      COUNT(*)
    ----------
             0
     
    SQL> create or replace function f return number is
      2    l_cpt  pls_integer;
      3  begin
      4    select count(*)
      5      into l_cpt
      6      from tab_a;
      7    return l_cpt;
      8  end;
      9  /
     
    Function created.
     
    SQL> show err
    No errors.
    SQL>

Discussions similaires

  1. Appel de fonction dans une procédure stockée
    Par Nuloprog dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 22/12/2008, 16h00
  2. Appel d'une fonction dans une procédure
    Par dingo200 dans le forum PL/SQL
    Réponses: 16
    Dernier message: 07/11/2008, 16h03
  3. Appel d'une procédure stockée dans une procédure stockée
    Par MrEddy dans le forum MS SQL Server
    Réponses: 2
    Dernier message: 13/09/2006, 16h17
  4. Réponses: 3
    Dernier message: 17/01/2006, 17h12
  5. Appel d'un script SQL dans une procdure stockée
    Par doudou10000 dans le forum Oracle
    Réponses: 10
    Dernier message: 01/12/2004, 10h01

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