当前位置:  数据库>oracle

Oracle hint 实践一列 leanding 驱动表和hash多块读取

    来源: 互联网  发布时间:2017-04-19

    本文导语: 由于数据库对表没有做及时的分析, Oss_User_Beh_Sum_Day_201110  这个是大表 这个是按天自动物理创建的表. 由于代码没有把字典表放在第一位置. Oracle 默认执行计划先访问大表,从右往左是第一个. 然后再访问字典表.在执行计划中字典...

由于数据库对表没有做及时的分析, Oss_User_Beh_Sum_Day_201110  这个是大表 这个是按天自动物理创建的表.

由于代码没有把字典表放在第一位置. Oracle 默认执行计划先访问大表,从右往左是第一个.

然后再访问字典表.在执行计划中字典表采用索引访问,从上往下是最后一个,垫底的.

最后两个表采用NEER LOOP 连接.

所以采用提示符 /*+leading(b)*/  当数据库内存大 可以采用/*+use_hash(b,a)*/ 采用哈希连接 把大部分数据读到内存匹配,采用多块读取,而嵌套循环连接采用单块读取到内存.

下面两条语句可以放在PL/SQL DEVELOPERWINDOWSF8运行 就可以看到执行计划.

一般ORACLE 对表做了分析会智能地采用某个表做驱动表,当不一定会采用HASH连接.

Explain Plan For
   Select     /*+use_hash(b,a) leading(b)*/ 
   Count(Distinct(Usernumber)),       
   Sum(a.Totalcount),       
   a.Provcode,       
   a.areacode,       
   From User_Day_201110 a, Report_Dic_Info b ,
 Where a.Operid = b.Operid    
 And a.Recdate = :Pi_Dutydate 
 Group By a.Provcode,          
         a.Areacode,          
         a.Serviceid,                
         a.Bindtypeid;
   Select * From Table(dbms_xplan.display());













    
 
 

您可能感兴趣的文章:

  • linux下通过对文件读取方式查询oracle的版本信息
  • 读取oracle数据库表写文件慢
  • 用oracle pl/sql 从A unix机器,去读取B unix机器上的一个文件,怎么实现?
  • Oracle除去数据中的换行符以免读取出现问题
  • 请问如何用Java从Oracle数据库中读取媒体文件,如图片,mpeg 等
  • apache通过php的oci函数读取Oracle(字符集ZHS16GBK)时,显示乱码,如何解决?
  • linux下用什么办法连接oracle数据库并且读取数据呢?(用c++代码实现时)
  • jsp读取oracle8.1.6数据表中的中文,读出为?,着急啊。
  • 小妹求教!!关于jsp操作oracle数据库操作的问题(文件读取,插入数据库表相应字段中)
  • 请问oracle的clob字段可不可以存富文本的文件,like .doc .rtf?如果可以如何用java读取?
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle SQL最佳实践
  • Oracle PL/SQL入门案例实践
  • Oracle数据库备份恢复最佳实践
  • Oracle 12c发布简单介绍及官方下载地址
  • 在linux下安装oracle,如何设置让oracle自动启动!也就是让oracle那个服务自动启动,不是手动的
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • Oracle数据库(Oracle Database)体系结构及基本组成介绍
  • Oracle 数据库开发工具 Oracle SQL Developer
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle EBS R12 支持 Oracle Database 11g
  • Oracle 10g和Oracle 11g网格技术介绍
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • Oracle 数据库(oracle Database)性能调优技术详解
  • Linux /$ORACLE_HOME $ORACLE_HOME
  • ORACLE日期相关操作
  • Linux系统下Oracle的启动与Oracle监听的启动
  • ORACLE数据库常用字段数据类型介绍
  • 请问在solaris下安装ORACLE,用root用户和用oracle用户安装有什么区别么?
  • Oracle 12c的九大最新技术特性介绍
  • 网间Oracle的连接,远程连接Oracle服务器??


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,