gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-12-04 17:55:51 25 4
gpt4 key购买 nike

在创建一个数据库链接之前,我需要检查一个数据库链接是否已经存在。我怎样才能做到这一点?

我正在编写一个以此开头的 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 数据库链接。检查是否存在或覆盖?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9200235/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com