使用Oracle DBLink进行数据库之间对象的访问操作
2017-04-25 11:31
525 查看
Oracle中自带了DBLink功能,它的作用是将多个oracle数据库逻辑上看成一个数据库,也就是说在一个数据库中可以操作另一个数据库中的对象,例如我们新建了一个数据database1,我们需要操作数据库database2中的表,或者我们需要操作远程机器上数据库database3中的表,我们就可以使用dblink这个强大的功能!
1、我们如果要创建全局的DBLink,就是说无论什么角色都可以使用,那么我们需要先确定用户是否有DBLink权限,如果没有则需要使用sysdba角色给用户授权:
查看用户是有有DBLink权限:
[sql] view plain copy print?select * from user_sys_privs where privilege like upper(‘%DATABASE LINK%’);
[sql] view plain copy print?grant create public database link to dbusername;
2、使用语句创建DBLink:
[sql] view plain copy print?create database link 要创建的dblink名称
connect to 要连接数据库的用户名 identified by 要连接数据的密码
using ’(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 连接数据库主机IP地址)(PORT = 端口号))
)
(CONNECT_DATA =
(SERVICE_NAME = 连接数据库服务名)
)
)’;
[sql] view plain copy print?create public database….
[sql] view plain copy print?create database link tset_dblink
connect to username identified by password1
using ’(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.254)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = testdb1)
)
)’;
3、使用DBLink:
查询另一个数据库中的数据,其他修改、删除是一样的使用,都是另一个数据库表名@本数据库创建dblink名称:
[sql] view plain copy print?select xxx FROM 表名@dblink名称;
例如我们在testdb2中使用dblink查看testdb1中tb_user表中的数据:
[sql] view plain copy print?select * from tb_user@tset_dblink;
查看数据中创建的dblink:
[sql] view plain copy print?select owner,object_name from dba_objects where object_type=‘DATABASE LINK’;
select * from dba_db_links;
[sql] view plain copy print?drop database link dblink名称;
[sql] view plain copy print?alter session close database link ‘dblink_name’
[sql] view plain copy print?create or replace view 视图名 as (select 字段 from 用户.表名@dblink1);
drop view 视图名;
1、我们如果要创建全局的DBLink,就是说无论什么角色都可以使用,那么我们需要先确定用户是否有DBLink权限,如果没有则需要使用sysdba角色给用户授权:
查看用户是有有DBLink权限:
[sql] view plain copy print?select * from user_sys_privs where privilege like upper(‘%DATABASE LINK%’);
select * from user_sys_privs where privilege like upper('%DATABASE LINK%');没有,则使用sysdba授权:
[sql] view plain copy print?grant create public database link to dbusername;
grant create public database link to dbusername;
2、使用语句创建DBLink:
[sql] view plain copy print?create database link 要创建的dblink名称
connect to 要连接数据库的用户名 identified by 要连接数据的密码
using ’(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 连接数据库主机IP地址)(PORT = 端口号))
)
(CONNECT_DATA =
(SERVICE_NAME = 连接数据库服务名)
)
)’;
create database link 要创建的dblink名称 connect to 要连接数据库的用户名 identified by 要连接数据的密码 using '(DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 连接数据库主机IP地址)(PORT = 端口号)) ) (CONNECT_DATA = (SERVICE_NAME = 连接数据库服务名) ) )';如果创建全局 dblink,必须使用 systm 或 sys 用户,在 database 前加 public:
[sql] view plain copy print?create public database….
create public database....例如,在testdb2中创建test_dblink,来操作主机192.168.1.254中testdb1数据库:
[sql] view plain copy print?create database link tset_dblink
connect to username identified by password1
using ’(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.254)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = testdb1)
)
)’;
create database link tset_dblink connect to username identified by password1 using '(DESCRIPTION = (ADDRESS_LIST = (ADDRESS = (PROTOCOL = TCP)(HOST = 192.168.1.254)(PORT = 1521)) ) (CONNECT_DATA = (SERVICE_NAME = testdb1) ) )';
3、使用DBLink:
查询另一个数据库中的数据,其他修改、删除是一样的使用,都是另一个数据库表名@本数据库创建dblink名称:
[sql] view plain copy print?select xxx FROM 表名@dblink名称;
select xxx FROM 表名@dblink名称;
例如我们在testdb2中使用dblink查看testdb1中tb_user表中的数据:
[sql] view plain copy print?select * from tb_user@tset_dblink;
select * from tb_user@tset_dblink;
查看数据中创建的dblink:
[sql] view plain copy print?select owner,object_name from dba_objects where object_type=‘DATABASE LINK’;
select * from dba_db_links;
select owner,object_name from dba_objects where object_type='DATABASE LINK'; select * from dba_db_links;删除相应的dblink:
[sql] view plain copy print?drop database link dblink名称;
drop database link dblink名称;关闭dblink连接:
[sql] view plain copy print?alter session close database link ‘dblink_name’
alter session close database link 'dblink_name'创建和删除视图:
[sql] view plain copy print?create or replace view 视图名 as (select 字段 from 用户.表名@dblink1);
drop view 视图名;
create or replace view 视图名 as (select 字段 from 用户.表名@dblink1); drop view 视图名;
相关文章推荐
- 使用Oracle DBLink进行数据库之间对象的访问操作
- 使用Oracle DBLink进行数据库之间对象的訪问操作
- Oracle--DBLink 进行数据库之间对象的访问操作
- Oracle两个数据库互相访问,DBLink使用-转
- 【Python Oracle】使用cx_Oracle 进行数据库操作介绍
- PowerDesigner中使用vbscript访问对象进行批量操作
- SharePoint服务器端对象模型 之 使用LINQ进行数据访问操作(Part 1)
- Oracle两个数据库访问,DbLink使用
- 大量使用oracle DBLINK影响本地数据库的正常操作(过渡使用)
- thinkphp 实例化对象时,已经进行了数据库的访问操作
- SharePoint服务器端对象模型 之 使用LINQ进行数据访问操作(Part 4)
- Oracle两个数据库互相访问,DBLink使用
- Oracle 远程访问配置 在 Windows Forms 和 WPF 应用中使用 FontAwesome 图标 C#反序列化XML异常:在 XML文档(0, 0)中有一个错误“缺少根元素” C#[Win32&WinCE&WM]应用程序只能运行一个实例:MutexHelper Decimal类型截取保留N位小数向上取, Decimal类型截取保留N位小数并且不进行四舍五入操作
- SharePoint服务器端对象模型 之 使用LINQ进行数据访问操作(Part 3)
- SharePoint 服务器端对象模型 之 使用LINQ进行数据访问操作(Part 2)
- ORACLE跨数据库操作,DBLINK的使用
- Oracle DBLINK 简单使用 oracle在进行跨库访问时,可以通过创建dblink实现,今天就简单的介绍下如果创建dblink,以及通过dblink完成插入、修改、删除等操
- oracle使用四(数据库对象)
- PowerDesigner中使用vbscript访问对象进行批量操作
- 数据库操作_连接SQL Server数据库示例;连接ACCESS数据库;连接到 Oracle 数据库示例;SqlCommand 执行SQL命令示例;SqlDataReader 读取数据示例;使用DataAdapter填充数据到DataSet;使用DataTable存储数据库表;将数据库数据填充到 XML 文件;10 使用带输入参数的存储过程;11 使用带输入、输出参数的存储过程示;12 获得数据库中表的数目和名称;13 保存图片到SQL Server数据库示例;14 获得插入记录标识号;Exce