对于使用DBLINK远程访问数据库的SQL,ORACLE可以有两种选择:
第一:在Remote数据库执行该段SQL;
第二:在Local数据库执行该段SQL;
所以优化策略和思路:
策略:远程访问,网络传输占很大部分,优化原则,减少网络传输,将小的结果集拉到本地处理;
思路1:可以在远端数据库建立视图,在远端执行;
思路2:使用DRIVING_SITE将数据拉到本地执行处理;
用法: /+driving_site(table_name)/ : table_name 一般是大表,以该表作为驱动表;
例如如下SQL:
select /*+ driving_site(o) */
o.column1,
p.column1
from table_1@remote_link o ,table p
where o.ID=p.ID;
以上我们可以看出table_1是Remote数据库表,在/*+ driving_site(o) */的影响下,oracle会把table_2通过remote_link发送到Remote数据库,在Remote进行连接查询,然后将查询结果返回到Local,所以如果table_1是个大的数据table则会减少网络传输,提升SQL运行性能。