通过pl/sql把oracle类型的两个不同主机的数据库在同一个sql方式中操作

--使用服务名创建一个dblink
create database link testjxreal connect to fruitking identified by f123456 using 'testjx_db78';
--服务名指的是${oracle_home}\product\10.2.0\db_1\NETWORK\ADMIN\tnsnames.ora文件添加的那段代码
testjx_db78=(DESCRIPTION =
                (ADDRESS_LIST =
                    (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.78)(PORT = 1521)))
                    (CONNECT_DATA =(SERVICE_NAME = orcl))
             )
--使用dblink访问数据库中的表
select * from enterprise@testjxreal;
--删除一个dblink
drop database link  testjxreal;

--查看全球服务名SID
SELECT * FROM GLOBAL_NAME;
--查看SID的参数状态,这个需要在sql命令行形式执行
show parameter global_name;

--直接建立一个连接,这样避免使用服务名,有时使用服务名会导致TNS找不到服务名的错误/异常,从而无法连接
-- 第一个参数:创建的连接名字,这个名字你可以随你实际自由命名
-- 第二个参数:数据库用户名(访问数据库创建的用户,可以是dba,也可以是普通用户)
-- 第三个参数:数据库用户密码
-- 第四个参数:数据库主机IP地址
-- 第五个参数:数据库SID
create database link testjxreal
connect to fruitking identified by f123456
using '(DESCRIPTION =
           (ADDRESS_LIST =
               (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.78)(PORT = 1521)))
               (CONNECT_DATA =(SERVICE_NAME = orcl)
           )
       )';
--使用dblink访问数据库中的表
select * from enterprise@testjxreal;

你可能感兴趣的:(oracle,sql)