909422229_数据库优化

Sql 优化:

Oracle数据库拿到SQL语句时,其会根据查询优化器分析该语句,并根据分析结果生成查询执行计划。

也就是说,数据库是执行的查询计划,而不是Sql语句。

 

1、先执行From ->Where ->Group By->Order By 执行From 字句是从右往左进行执行。因此必须选择记录条数最少的表放在右边。这是为什么呢?  

对于Where字句其执行顺序是从后向前执行、因此可以过滤最大数量记录的条件必须写在Where子句的末尾,而对于多表之间的连接,则写在之前。因为这样进行连接时,可以去掉大多不重复的项。  

 

2. SELECT子句中避免使用(*)ORACLE在解析的过程中, 会将’*’ 依次转换成所有的列名, 这个工作是通过查询数据字典完成的, 这意味着将耗费更多的时间

 

3.sql语句尽量简单,复杂的sql会降低程序的运行效率。

 

4.对于不经常修改的表,可以利用缓存的技术放到缓存中,例如:redis内存缓存中,提高查询效率。

 

5.sql语句要大写,即使小写也会转变成大写,省去了转换的步骤,而且不要用*号。因为oracle中会存取缓存,如果是相同的查询类型,会直接获取,如果是*的话每次都需要进行全表查询。降低了效率。

 

6.可以借用索引提高效率,但是随着数据的增加,索引的维护成为一个问题

 

7.对查询进行优化,应尽量避免全表扫描,首先应考虑在 where order by 涉及的列上建立索引

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

75888丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值