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

Administration Oracle Discussion :

[ORACLE] database link


Sujet :

Administration Oracle

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 10
    Points : 7
    Points
    7
    Par défaut [ORACLE] database link
    Salut à tous,

    Voici mon souci. Je crée un database link entre 2 bases.
    J'utilise donc la syntaxe "create database link <nomdblink> connect to <user> identified by <pass> using '<db>'". Jusqu'ici tout va bien, cela fonctionne sans pb.
    Là où ça ne fonctionne pas, c'est quand je veux utiliser une procédure stockée pour faire le boulot. Voici le code de ma belle procédure :

    PROCEDURE SP_CREATE_DBLINK(dblink_name VARCHAR2, dblink_user VARCHAR2, dblink_passwd VARCHAR2, db_link_dbname VARCHAR2) IS

    dblink_count INTEGER;
    dblink_drop VARCHAR2(150);
    dblink_create VARCHAR2(150);

    BEGIN

    select count(*)
    into dblink_count
    FROM all_db_links
    WHERE lower(db_link) = dblink_name;

    dblink_drop := 'drop database link ' || dblink_name;
    dblink_create := 'create database link ' || dblink_name || ' connect to ' || dblink_user || ' identified by ' || dblink_passwd || ' using ''' || db_link_dbname || '''';

    if dblink_count > 0
    then
    begin
    execute immediate dblink_drop;
    dbms_output.put_line('drop database link : ' || dblink_name);
    end;
    end if;

    execute immediate dblink_create;

    END SP_CREATE_DBLINK;
    A l'exécution, j'obtiens le message suivant :

    *
    ERROR at line 1:
    ORA-01031: insufficient privileges
    ORA-06512: at "PDA_CONF.CHECKSV2", line 427
    ORA-06512: at line 1
    La ligne 427 correspondant à mon "execute immediate dblink_create;"

    Quelqu'un aurait une idée ? Je ne comprends pas pourquoi je n'aurais pas les droits, car cela fonctionne en ligne de commande, mais pas dans une procédure. Ca ne me semble pas logique car ce sont les mêmes comptes qui sont utilisés, mais je suis loin d'être une expert alors je m'en remets à vous...
    Si c'est effectivement un problème de droit, merci de bien vouloir m'indiquer comment enquêter là dessus :-)

    A+

  2. #2
    Membre expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Points : 3 609
    Points
    3 609
    Par défaut
    Les droits pour créer un databaselink doivent être hérités d'un rôle. Or en PL/SQL et en sql dynamique ils doivent t'être donnés directement via un grant.

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 10
    Points : 7
    Points
    7
    Par défaut
    Pourrais-tu stp m'éclaircir un peu sur le grant ?

  4. #4
    Membre expert

    Homme Profil pro
    Chef de projet en SSII
    Inscrit en
    Janvier 2004
    Messages
    2 862
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Chef de projet en SSII
    Secteur : Conseil

    Informations forums :
    Inscription : Janvier 2004
    Messages : 2 862
    Points : 3 609
    Points
    3 609
    Par défaut
    Sous le compte sys :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    grant create database link to tonUser;

  5. #5
    Futur Membre du Club
    Profil pro
    Inscrit en
    Octobre 2005
    Messages
    10
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2005
    Messages : 10
    Points : 7
    Points
    7
    Par défaut
    Merci beaucoup :-)

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

Discussions similaires

  1. Database link entre Mysql et une base Oracle
    Par lcloatre dans le forum Administration
    Réponses: 1
    Dernier message: 27/04/2010, 09h48
  2. odbc oracle/database link
    Par jzbtrax10n dans le forum Access
    Réponses: 0
    Dernier message: 26/05/2008, 13h54
  3. DATABASE LINK ORACLE
    Par RODAK dans le forum Oracle
    Réponses: 3
    Dernier message: 31/03/2006, 00h03
  4. Database link Oracle et Delphi 6
    Par glogla dans le forum Bases de données
    Réponses: 2
    Dernier message: 27/02/2006, 10h49
  5. Utilisation de database link avec Oracle 9i+
    Par moezsokrati dans le forum Oracle
    Réponses: 1
    Dernier message: 21/01/2006, 17h45

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