简单介绍Oracle驱动表

Oracle有很多值得学习的地方,这里我们主要介绍Oracle驱动表,包括介绍hints的用法等方面。CBO根据统计信息选择Oracle驱动表,假如没有统计信息,则在from 子句中从左到右的顺序选择Oracle驱动表。这与RBO选择的顺序正好相反。这是英文原文(CBO determines join order from costs derived from gathered statistics. If there are no stats then CBO chooses the driving order of tables from LEFT to RIGHT in the FROM clause. This is OPPOSITE to the RBO) 。

10年积累的网站建设、网站制作经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站制作后付款的网站建设流程,更有揭阳免费网站建设让你可以放心的选择与我们合作。

我还是没法证实这句话的正确性。不过经过验证:“如果用ordered 提示(此时肯定用CBO),则以from 子句中按从左到右的顺序选择Oracle驱动表”这句话是正确的。实际上在CBO中,如果有统计数据(即对表与索引进行了分析),则优化器会自动根据cost值决定采用哪种连接类型,并选择合适的Oracle驱动表,这与where子句中各个限制条件的位置没有任何关系。如果我们要改变优化器选择的连接类型或Oracle驱动表,则就需要使用 hints了,具体hints的用法在后面会给予介绍。

如果我创建的3个表:

 
 
 
  1. create table A(col1 number(4,0),col2 number(4,0), col4 char(30));
  2. create table B(col1 number(4,0),col3 number(4,0), name_b char(30));
  3. create table C(col2 number(4,0),col3 number(4,0), name_c char(30));
  4. create index inx_col12A on a(col1,col2);

执行查询:

 
 
 
  1. select A.col4
  2. from B, A, C
  3. where B.col3 = 10
  4. and A.col1 = B.col1
  5. and A.col2 = C.col2
  6. and C.col3 = 5;
  7. Execution Plan

文章标题:简单介绍Oracle驱动表
链接分享:http://www.shufengxianlan.com/qtweb/news27/276927.html

网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联