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

 Oracle Discussion :

Problème de privilège


Sujet :

Oracle

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre très actif
    Profil pro
    Inscrit en
    Mars 2003
    Messages
    138
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2003
    Messages : 138
    Par défaut Problème de privilège
    Bonjour,
    J'ai un problème avec les privilèges.
    J'ai 2 users :
    -user1 avec la table table1
    -user2 doit veut pouvoir faire un select sur table1 de user1.

    Pour cela, je pensais utiliser un seul role pour les 2 users.

    Voici les commandes que je saisie (j'ai simplifiée les create user) :

    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
     
    CREATE USER user1;
     
    create table table1 (a int);
     
    create role ROLE1;
    GRANT CREATE TABLE,ALTER SESSION,CREATE SESSION TO ROLE1;
    create or replace directory datadir as 'monrep';
    grant read,write on directory datadir to ROLE1;
     
    GRANT ROLE1 to user1;
     
     
    GRANT SELECT, INSERT, UPDATE, DELETE ON user1.table1 TO ROLE1;
     
    CREATE USER user2;
    GRANT ROLE1 to user2;
    Si apres cela, je me connecte a user2, puis je fait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    select * from table1
    j'ai le message d'erreur

    ORA-00942: Table ou vue inexistante
    pour la table table1.

    Si apres tout cela, je refait :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    GRANT SELECT, INSERT, UPDATE, DELETE ON user1.table1 TO ROLE1;
    Alors la c'est bon, l'utilisateur user2 peut faire une requette sur user1.table1.

    Est-ce qu'il y a une explication a ce drole de fonctionnement ?
    Il y a peut être un problème entre les privilèges systemes et les privilèges objets, mais je suis débutant en Oracle.

    Pour information, je travaille avec Oracle 10 XE.

  2. #2
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 462
    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 462
    Par défaut
    ne peut pas fonctionner si vous n'avez pas défini de synonyme.
    Il faut préfixer par le propriétaire de la table :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    select * from user1.table1;

  3. #3
    Membre très actif
    Profil pro
    Inscrit en
    Mars 2003
    Messages
    138
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2003
    Messages : 138
    Par défaut
    Oui vous avez raison, c'est votre requette que je faisais.
    Cependant, je ne sais pas pourquoi, apres une enieme tentative, cela fonctionne.

    Donc c'est réglé. Merci beaucoup.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 2
    Dernier message: 14/11/2007, 14h29
  2. Problème de privilèges insuffisants
    Par lokazouzou dans le forum Oracle
    Réponses: 1
    Dernier message: 08/10/2007, 09h30
  3. Réponses: 2
    Dernier message: 06/12/2006, 08h54
  4. Problèmes de privilèges pour mes rôles
    Par missbug dans le forum PostgreSQL
    Réponses: 3
    Dernier message: 06/07/2006, 10h31
  5. [10g] Problème de privilège dans une requête
    Par hotkebab99 dans le forum Oracle
    Réponses: 6
    Dernier message: 01/03/2006, 12h00

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