Oracle多表查询优化的代码示例

如果你是Oracle多表查询优化方面的新手,对Oracle多表查询优化的相关实际应用不是很了解的话,以下的文章会给你提供更全面的知识。以下就是文章的详细内容的介绍,望你会有所了解。

创新互联建站不只是一家网站建设的网络公司;我们对营销、技术、服务都有自己独特见解,公司采取“创意+综合+营销”一体化的方式为您提供更专业的服务!我们经历的每一步也许不一定是最完美的,但每一步都有值得深思的意义。我们珍视每一份信任,关注我们的成都网站建设、成都网站设计质量和服务品质,在得到用户满意的同时,也能得到同行业的专业认可,能够为行业创新发展助力。未来将继续专注于技术创新,服务升级,满足企业一站式网络营销推广需求,让再小的品牌网站设计也能产生价值!

Oracle采用自下而上的顺序解析WHERE子句,根据这个原理,表之间的连接必须写在其他WHERE条件之前, 那些可以过滤掉***数量记录的条件必须写在WHERE子句的末尾.

例如:

(低效,执行时间156.3秒)

 
 
 
  1. SELECT …
  2. FROM EMP E
  3. WHERE SAL >; 50000
  4. AND JOB = ‘MANAGER’
  5. AND 25 < (SELECT COUNT(*) FROM EMP
  6. WHERE MGR=E.EMPNO);

(高效,执行时间10.6秒)

 
 
 
  1. SELECT …
  2. FROM EMP E
  3. WHERE 25 < (SELECT COUNT(*) FROM EMP
  4. WHERE MGR=E.EMPNO)
  5. AND SAL >; 50000
  6. AND JOB = ‘MANAGER’;

重点关注3:SELECT子句中避免使用 ‘ * ‘ .重点关注

当你想在SELECT子句中列出所有的COLUMN时,使用动态SQL列引用 ‘*’ 是一个方便的方法.不幸的是,这是一个非常低效的方法. 实际上,Oracle在解析的过程中, 会将’*’ 依次转换成所有的列名, 这个工作是通过Oracle多表查询数据字典完成的, 这意味着将耗费更多的时间.

7. 减少访问数据库的次数

当执行每条SQL语句时, Oracle在内部执行了许多工作: 解析SQL语句, 估算索引的利用率, 绑定变量 , 读数据块等等. 由此可见, 减少访问数据库的次数 , 就能实际上减少Oracle的工作量.

例如,

以下有三种方法可以检索出雇员号等于0342或0291的职员.

方法1 (***效)

 
 
 
  1. SELECT EMP_NAME , SALARY , GRADE
  2. FROM EMP
  3. WHERE EMP_NO = 342;
  4. SELECT EMP_NAME , SALARY , GRADE
  5. FROM EMP
  6. WHERE EMP_NO = 291;

方法2 (次低效)

 
 
 
  1. DECLARE
  2. CURSOR C1 (E_NO NUMBER) IS
  3. SELECT EMP_NAME,SALARY,GRADE
  4. FROM EMP
  5. WHERE EMP_NO = E_NO;
  6. BEGIN
  7. OPEN C1(342);
  8. FETCH C1 INTO …,..,.. ;
  9. OPEN C1(291);
  10. FETCH C1 INTO …,..,.. ;
  11. CLOSE C1;
  12. END;

以上的相关内容就是对Oracle多表查询优化的介绍,望你能有所收获。


网页题目:Oracle多表查询优化的代码示例
网站URL:http://www.gydahua.com/article/dpohghc.html
扫二维码与项目经理沟通

我们在微信上24小时期待你的声音

解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流