天天看点

Oracle中Driving_site Hint的用法

对于使用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 [email protected]_link o ,table p
where o.ID=p.ID;
           

以上我们可以看出table_1是Remote数据库表,在的影响下,oracle会把table_2通过remote_link发送到Remote数据库,在Remote进行连接查询,然后将查询结果返回到Local,所以如果table_1是个大的数据table则会减少网络传输,提升SQL运行性能。