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)
相关推荐
MonkeyKing_sunyuhua32 分钟前
ubuntu22.04 docker-compose安装postgresql数据库
数据库·docker·postgresql
天郁青33 分钟前
数据库交互的本地项目:后台管理系统
数据库·交互
马剑威(威哥爱编程)38 分钟前
MongoDB面试专题33道解析
数据库·mongodb·面试
小光学长1 小时前
基于vue框架的的流浪宠物救助系统25128(程序+源码+数据库+调试部署+开发环境)系统界面在最后面。
数据库·vue.js·宠物
零炻大礼包2 小时前
【SQL server】数据库远程连接配置
数据库
zmgst2 小时前
canal1.1.7使用canal-adapter进行mysql同步数据
java·数据库·mysql
随心............2 小时前
python操作MySQL以及SQL综合案例
数据库·mysql
€☞扫地僧☜€2 小时前
docker 拉取MySQL8.0镜像以及安装
运维·数据库·docker·容器
CopyDragon2 小时前
设置域名跨越访问
数据库·sqlite
xjjeffery2 小时前
MySQL 基础
数据库·mysql