SQL查询优化、SQL执行计划及优化器之间什么关系
发布网友
发布时间:2022-05-01 22:28
我来回答
共1个回答
热心网友
时间:2022-05-01 23:57
一,SQL查询优化:指,使用的语句是不是冗余的,就是有没有无用的。
你可用用explain 你的语句来比较分板一番。比如:select * from wc where 1;与select * from wc二者的执行时间不一样的;
二,SQL执行计划就是用于描述SQL引擎在执行一个sql语句时的所有步骤,通过执行计划,我们可以知道哪个表是驱动表,如何访问一个表:是通过索引访问还是通过表扫描,如何进行连接:使用嵌套连接,合并连接还是哈希连接,连接的顺序等等;
在我们处理执行计划的过程中,一般有三个步骤:
获取执行计划
理解执行计划
判断其效率
2.获取执行计划的方式
Oracle提供了以下几种方法获得sql语句的执行计划:
2.1 explain plan
这种方法用于给出当前的sql文本的评估的执行计划,oracle并不会执行相应的sql语句,而且如果sql语句有绑定参数,那么得到的执行计划并不一定就是确切的执行计划,还要根据条件中的列是否有直方图和cursor_sharing参数的配置值来判断。
a. 在sqlplus 中执行explain plan
SQL>Explain plan set sql_id=’mysql’ for select * from temp;
b. 使用dbms_xplan显示执行计划
select * from table(dbms_xplan.display());
或者:select * from table(dbms_xplan.display(statement_id => ‘mysql’));
三,优化器;是SQL执行效率的重构工具。
可以帮助将低效率的SQL优化成为高效率的。
一般主要针对查询语句。
将更多的判断条件已到叶子节点上去操作。追问执行计划与查询优化有什么关系,查询语句是按执行计定义的步骤执行的,查询优化是不是包括制定有效的执行计划,还是制定有效的执行计划就是查询优化