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)
相关推荐
兩尛1 小时前
订单状态定时处理、来单提醒和客户催单(day10)
java·前端·数据库
web2u1 小时前
MySQL 中如何进行 SQL 调优?
java·数据库·后端·sql·mysql·缓存
Elastic 中国社区官方博客2 小时前
使用 Elasticsearch 导航检索增强生成图表
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
小金的学习笔记2 小时前
RedisTemplate和Redisson的使用和区别
数据库·redis·缓存
新知图书2 小时前
MySQL用户授权、收回权限与查看权限
数据库·mysql·安全
文城5212 小时前
Mysql存储过程(学习自用)
数据库·学习·mysql
沉默的煎蛋3 小时前
MyBatis 注解开发详解
java·数据库·mysql·算法·mybatis
呼啦啦啦啦啦啦啦啦3 小时前
【Redis】事务
数据库·redis·缓存
HaoHao_0103 小时前
AWS Serverless Application Repository
服务器·数据库·云计算·aws·云服务器
C语言扫地僧3 小时前
MySQL 事务及MVCC机制详解
数据库·mysql