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多表查询优化的代码示例
当前链接:http://www.mswzjz.cn/qtweb/news14/288314.html

攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

广告

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