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 涉及的列上建立索引