Oracle中Driving_site Hint的用法

Oracle中Driving_site Hint的用法

夜袭_Yang

于 2020-04-14 00:36:17 发布

761
收藏 1
分类专栏: SQL Tuning 文章标签: 数据库 sql oracle
版权

SQL Tuning
专栏收录该内容
5 篇文章0 订阅
订阅专栏
对于使用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;
1
2
3
4
5
以上我们可以看出table_1是Remote数据库表,在/*+ driving_site(o) */的影响下,oracle会把table_2通过remote_link发送到Remote数据库,在Remote进行连接查询,然后将查询结果返回到Local,所以如果table_1是个大的数据table则会减少网络传输,提升SQL运行性能。
————————————————
版权声明:本文为CSDN博主「夜袭_Yang」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/sinat_27431397/article/details/105501431

posted @ 2022-02-22 13:40  耀阳居士  阅读(567)  评论(0)    收藏  举报