如果你是Oracle多表查询优化方面的新手,对Oracle多表查询优化的相关实际应用不是很了解的话,以下的文章会给你提供更全面的知识。以下就是文章的详细内容的介绍,望你会有所了解。
创新互联建站不只是一家网站建设的网络公司;我们对营销、技术、服务都有自己独特见解,公司采取“创意+综合+营销”一体化的方式为您提供更专业的服务!我们经历的每一步也许不一定是最完美的,但每一步都有值得深思的意义。我们珍视每一份信任,关注我们的成都网站建设、成都网站设计质量和服务品质,在得到用户满意的同时,也能得到同行业的专业认可,能够为行业创新发展助力。未来将继续专注于技术创新,服务升级,满足企业一站式网络营销推广需求,让再小的品牌网站设计也能产生价值!
Oracle采用自下而上的顺序解析WHERE子句,根据这个原理,表之间的连接必须写在其他WHERE条件之前, 那些可以过滤掉***数量记录的条件必须写在WHERE子句的末尾.
例如:
(低效,执行时间156.3秒)
- SELECT …
- FROM EMP E
- WHERE SAL >; 50000
- AND JOB = ‘MANAGER’
- AND 25 < (SELECT COUNT(*) FROM EMP
- WHERE MGR=E.EMPNO);
(高效,执行时间10.6秒)
- SELECT …
- FROM EMP E
- WHERE 25 < (SELECT COUNT(*) FROM EMP
- WHERE MGR=E.EMPNO)
- AND SAL >; 50000
- AND JOB = ‘MANAGER’;
重点关注3:SELECT子句中避免使用 ‘ * ‘ .重点关注
当你想在SELECT子句中列出所有的COLUMN时,使用动态SQL列引用 ‘*’ 是一个方便的方法.不幸的是,这是一个非常低效的方法. 实际上,Oracle在解析的过程中, 会将’*’ 依次转换成所有的列名, 这个工作是通过Oracle多表查询数据字典完成的, 这意味着将耗费更多的时间.
7. 减少访问数据库的次数
当执行每条SQL语句时, Oracle在内部执行了许多工作: 解析SQL语句, 估算索引的利用率, 绑定变量 , 读数据块等等. 由此可见, 减少访问数据库的次数 , 就能实际上减少Oracle的工作量.
例如,
以下有三种方法可以检索出雇员号等于0342或0291的职员.
方法1 (***效)
- SELECT EMP_NAME , SALARY , GRADE
- FROM EMP
- WHERE EMP_NO = 342;
- SELECT EMP_NAME , SALARY , GRADE
- FROM EMP
- WHERE EMP_NO = 291;
方法2 (次低效)
- DECLARE
- CURSOR C1 (E_NO NUMBER) IS
- SELECT EMP_NAME,SALARY,GRADE
- FROM EMP
- WHERE EMP_NO = E_NO;
- BEGIN
- OPEN C1(342);
- FETCH C1 INTO …,..,.. ;
- OPEN C1(291);
- FETCH C1 INTO …,..,.. ;
- CLOSE C1;
- END;
以上的相关内容就是对Oracle多表查询优化的介绍,望你能有所收获。
文章题目:Oracle多表查询优化的代码示例
当前链接:http://www.mswzjz.cn/qtweb/news14/288314.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能