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 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运行性能。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值