Oracle数据库链接.检查是否存在或覆盖



在创建数据库链接之前,我需要检查数据库链接是否已经存在。我该怎么做?

我正在写一个SQL脚本,它的开头是:

DROP DATABASE LINK mydblink

然后我创建一个:

CREATE DATABASE LINK mydblink
CONNECT TO testuser
IDENTIFIED BY mypswd
USING 'mypersonaldb'

如果数据库链接不存在,我当然会在第一步中得到一个错误。如果我省略了第一步,只是继续创建一个数据库链接,我会再次收到一个错误,说它已经存在,并且具有相同的名称。

我可以做些什么来检查数据库链接是否已经存在?

SELECT COUNT(1)
  FROM dba_objects -- user_objects
 WHERE object_type = 'DATABASE LINK'
   AND object_name = 'ARGUS51P';

例如(未经测试):

declare
  l_link_cnt pls_integer := 0;
  l_sql varchar2(32767);
begin
  -- link creation sql (fill in details of how you want this created)
  l_sql := 'create public database link ...';
  select count(1)
  into l_link_cnt
  from dba_objects
  where object_type = 'DATABASE LINK'
  and object_name = 'SOME_LINK';
  -- create link if it doesn't exist yet
  if (l_link_cnt = 0) then
    -- create link 
    execute immediate l_sql;
  end if;
end;

Oracle无法在DROP或CREATE之前测试是否存在。(好吧,好吧,你可以写一些PL/SQL,但是,这可能比它的价值更麻烦。)在Oracle脚本中,在脚本中简单地同时执行DROP和CREATE是非常标准的。如果DROP出错,那就顺其自然。它不会影响脚本的执行。

-标记

相关内容

  • 没有找到相关文章

最新更新