zoukankan      html  css  js  c++  java
  • ORACLE SQL性能优化汇总

    ORACLE SQL语句共享

    Oracle SQL语句具备共享特性,为了不让ORACLE数据库重复解析相同的简单单表SQL语句,ORACLE在SGA系统共享区域内SBP共享池内存放的SQL语句将被所有用户共享。(注:只适合单表查询,多表连接查询无效!)
    ORACLE SQL语句共享,表现在三个方面
    1.字符级共享
    可简单理解为 SQL语句大小写区分
    如:
    select * from employee;

    select * From employee;
    Select * from Employee;
    以上三条语句ORACEL解析器会认为是三条不同的SQL语句,即不能共享
    2.绑定变量必须相同
    如:
    A
    1.select  username,password from user where id=:uid
    2.select  username,password from user where id=:uid
    B
    1.select  username,password from user where id=:uid
    2.select  username,password from user where id=:Kid
    A两条语句可共享,B两条语句绑定不同,不可共享
    3.语句所指对象必完全相同

    用户            对象                        访问权限
    ROOT             TAB1                      private
                     TAB2                      public
    ###############################
    AVEN             TAB1                      private
                     TAB2                      public
     SQL语句
    Q1. SELECT COUNT(*) FROM TAB1 ,不可共享,每一个用户有自己私有的表TAB1
    Q2. SELECT COUNT(*) FROM TAB2 ,可共享

    ORACLE SQL 多表联合查询

    ORACLE在多表查询时,选择合适的基础表进行查询,SQL效率会比较高!
    所谓基础表,是指在排在from后面的表列当中,最后一个位置的表称为基础表。
    ORACLE解析器在处理FROM子句时,会从FROM后面的最后一个表开始向前依次连接查询
    如selec t a.name ,b.code,c.content from A a,B b,C c where 。。。时,会先查询C表,再与B表连接,最后与A表连接查询。
    所以要选择适当的表作为基础表,放到from最后一个位置。
    在此处我们假设各表的记录数大小顺序为A<B<C表
    则优化语句不应该像以上SQL那样子写
    最优写法:selec t a.name ,b.code,c.content from  C c,B b,A a where 。。。
    最后要说明一点:对于交叉表查询,所谓交叉关联表作为基础表进行查询最优。所谓交叉表,举学生选课为例来说,学生表,课程表,选课情况表,这三张表当中,选课情况表为交叉表,应作为基础表进行查询。

    where语句条件顺序

    SQL语句中,where子句后面的所带的条件的顺序带来的优化!
    ORACLE解析器采用自下而上的方式解析WHERE子句。
    根据这一原理,我们应将能够一下过滤掉最大数量的条件应尽可能地放在WHERE子句的最后面,而对于关联表的连接查询,像这样的条件,刚尽可能地放在WHERE子句前面。
    举例说明,EMP员工表,MGR主管表,EMP的mrg_id为MGR表主键
    查询年纪大于50岁并且主管是‘XXX’的记录时。
    低效情况:
    select name,age from emp where age>50 and mrg_id in select(select id from mrg where name='xxx') ;
    高效情况:
    select name,age from emp where mrg_id in select(select id from mrg where name='xxx') and age>50;

    select 列引用符“*”

    在使用select语句时,避免使用动态sql语句列引用符“*”,当使用这个“*”,是一种相当低效的方法,oracle会先对对应的表所有列名解析一遍,那样子会相当的慢慢,最高效的方法是,在用到哪些列名时,直接写列名查询。最后还有一个注意点,在使用count内部函数时,也不用轻易使用“*”,改为select(pk) from tab_name去查询。

    ORACEL多表连接查询指定表别名alias

    建议在ORACEL多表连接查询时,所要查询出来字段前使用别名alias,使用别名的好处有两个
    第一,避免多表间存在同名列,而报错。举例,A表有字段c_column,B表也有字段c_column,SQL语句(select c_column from A,B WHERE XXXX)时,会报错,无法知道c_column归属哪张表
    第二,减少数据库解析时间,指定了别名,数据库解析器直接去查别名所在名的字段,加快查询速度。

    还有很多有关 oracle sql优化的规则请参考:

    http://www.cnblogs.com/rootq/archive/2008/11/17/1334727.html

     

     
  • 相关阅读:
    UDP and netstat
    UDP learn by Python3
    UDP headers and checksum
    routetrace
    IPv4 headers
    Commands for IP
    IP checksum
    POJ 3667 Hotel 线段树处理区间信息
    【枚举】Codeforces Round #432 (Div. 2, based on IndiaHacks Final Round 2017) Div2C题
    二分图最大匹配模板 HDU1083
  • 原文地址:https://www.cnblogs.com/harveylv/p/6829277.html
Copyright © 2011-2022 走看看