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 :
A l'exécution, j'obtiens le message suivant :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;
La ligne 427 correspondant à mon "execute immediate dblink_create;"*
ERROR at line 1:
ORA-01031: insufficient privileges
ORA-06512: at "PDA_CONF.CHECKSV2", line 427
ORA-06512: at line 1
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+
Partager