当前位置:Gxlcms > 数据库问题 > 公司组织oracle培训的理解

公司组织oracle培训的理解

时间:2021-07-01 10:21:17 帮助过:22人阅读

ps:以前看过sqlserver的执行流程 其实大概也是这样的

避免全表扫描提示查询效率

1、对于null值的查询会进行全表扫描的。所以我们在设计数据的时候对于可能出现null值的字段定义一个默认值 比如"-1" 或者一个‘’  那么当你要查询学生名为空的所有学生的时候:select * from table t.student.Name =‘-1‘

2、避免隐式转换 比如你在设计数据库的时候 UserId 设置的类型为number   你在客户端进查询的时候select * from user u where u.userid=‘1‘ 这种时候数据库和客户端传递的类型不一致 导致索引失效

3、避免查询条件使用函数 select * from user u where u.createTime=to_date(2017-01-02,‘yyyy-mm-dd‘) 这样也会导致索引失效 全表扫描

4、用exists 替换 in 因为in也会导致索引失效 比如查询班级为一年级的学生 select * from student where s.calssid in(select  classid from class  where calssName=‘一年级‘) 

    替换成 select * from student s where exists(select classid from class where className=‘一年级‘ and s.classsid=s.classid)

    当然这个举例有点极端

5、用union all 替换or

     比如你需要查询年龄为13 岁 或者 15岁 或者17岁的所有学生信息

     select * from student s where s.age in(13,15,17) 、

     替换成

     select * from student s where s.age=13

    union all

    select * from student s where s.age=15

    unoin all

    select * from student s where s.age=17

6.模糊查询 ‘%条件%‘  是全部扫描的 如果业务支持可以改成 ‘条件%‘ 是走索引的

7.join表不能超过3张(表与表之间的关联字段都建立索引) 如果业务支持 可以将数据查询到程序 程序再去取关联数据

      List<Student> students=dbhelper.query(select * from student where rownum<=10);

       student.ForEach(function(c){

        c.studentName=dbhelper.query(select * from class where classid=‘"+c.classId+‘).className

        })

ps:这里可能会觉得增加了数据库的负荷。因为取关联数据会给数据库发起10次请求  (其实这10次请求是非常快的 第一是数据库连接池   第二是 上面sql执行机制是直接运行的不会执行硬解析 因为这10条sql是一致的)

8、避免使用select *    *会导致oracle解析这个*表里面含有哪些列 而不是直接取。 * 会导致数据传输量 最好需要什么拿什么

总结:上面的优化操作 可能数据量小的时候感觉不到什么 但是上千万数据的时候 往往不规避以上的上的sql会查询很久  而规避了的sql只需要零点几秒

公司组织oracle培训的理解

标签:join   举例   student   函数   转换   注意   避免   默认   机制   

人气教程排行