explain分析sql执行计划

explain功能描述

显示SQL语句的执行计划。

执行计划将显示SQL语句所引用的表会采用什么样的扫描方式,如:简单的顺序扫描、索引扫描等。如果引用了多个表,执行计划还会显示用到的JOIN算法。

执行计划的最关键的部分是语句的预计执行开销,这是计划生成器估算执行该语句将花费多长的时间。

若指定了ANALYZE选项,则该语句会被执行,然后根据实际的运行结果显示统计数据,包括每个计划节点内时间总开销(毫秒为单位)和实际返回的总行数。这对于判断计划生成器的估计是否接近现实非常有用。

示例1:

sql 复制代码
--创建oceanbase表, 指定主键,索引,插入3条数据,测试explain
drop table test;
create table test
(
id bigint(20) NOT NULL AUTO_INCREMENT,
name varchar(50) DEFAULT NULL COMMENT '名称',
age bigint(3) DEFAULT NULL COMMENT '姓名',
PRIMARY KEY (id),
KEY idx_test_name (name)
) CHARSET = utf8mb4 COMMENT = '测试表';

insert into test(name,age) values ('one',10);
insert into test(name,age) values ('two',20);
insert into test(name,age) values ('three',30);

select * from test;
id	name	age
1	one	10
2	two	20
3	three	30

--oceanbase查看执行计划:
explain select * from test;
Query Plan
===================================
|ID|OPERATOR  |NAME|EST. ROWS|COST|
-----------------------------------
|0 |TABLE SCAN|test|3        |46  |
===================================

示例2:

sql 复制代码
--创建oracle表, 指定主键,索引,插入3条数据,测试explain
DROP TABLE test;
create table test
(
id int NOT NULL,
name varchar2(50) DEFAULT NULL ,
age int,
CONSTRAINT pk_id2 PRIMARY KEY (id)
) ;
CREATE INDEX idx_test_name ON test (name);

insert into test
select '1','one',10 FROM dual
 union all
select '2','two',20 FROM dual
 union all
select '3','three',30 FROM dual

--oracle查看执行计划:
EXPLAIN plan for select * from test;
SELECT plan_table_output FROM table(dbms_xplan.display())
PLAN_TABLE_OUTPUT
Plan hash value: 2545673168
--------------------------------------------------------------------------
| Id  | Operation         | Name | Rows  | Bytes | Cost (%CPU)| Time     |
--------------------------------------------------------------------------
|   0 | SELECT STATEMENT  |      |     3 |   159 |     3   (0)| 00:00:01 |
|   1 |  TABLE ACCESS FULL| TEST |     3 |   159 |     3   (0)| 00:00:01 |
--------------------------------------------------------------------------
Note
-----
   - dynamic statistics used: dynamic sampling (level=2)
相关推荐
kaixin_learn_qt_ing5 分钟前
解析Xml文件并修改QDomDocument的值
xml·数据库·qt
森林猿1 小时前
mongodb-数据备份和恢复
数据库·mongodb
oscube2 小时前
Apache AGE中的图
数据库·apache
科学的发展-只不过是读大自然写的代码2 小时前
qt播放视频
数据库·qt·音视频
激昂~逐流2 小时前
Qt使用sqlite数据库及项目实战
数据库·qt·sqlite·学生信息管理系统
svygh1233 小时前
数据库性能优化系统设计
数据库·性能优化·软件设计·系统设计·设计文档
wilsonzane4 小时前
Mongodb性能优化方法
数据库·mongodb
InterestingFigure4 小时前
Java 使用sql查询mongodb
java·开发语言·数据库·sql·mongodb
吹吹晚风-4 小时前
深入Django(三)
数据库·django·sqlite
xyh20044 小时前
python 10个自动化脚本
数据库·python·自动化