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)
相关推荐
luckys.one2 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
言之。3 小时前
Django中的软删除
数据库·django·sqlite
阿里嘎多哈基米4 小时前
SQL 层面行转列
数据库·sql·状态模式·mapper·行转列
抠脚学代码5 小时前
Ubuntu Qt x64平台搭建 arm64 编译套件
数据库·qt·ubuntu
jakeswang5 小时前
全解MySQL之死锁问题分析、事务隔离与锁机制的底层原理剖析
数据库·mysql
Heliotrope_Sun5 小时前
Redis
数据库·redis·缓存
一成码农5 小时前
MySQL问题7
数据库·mysql
吃饭最爱5 小时前
JUnit技术的核心和用法
数据库·oracle·sqlserver
专注API从业者5 小时前
Python/Java 代码示例:手把手教程调用 1688 API 获取商品详情实时数据
java·linux·数据库·python
雨落Liy6 小时前
SQL 函数从入门到精通:原理、类型、窗口函数与实战指南
数据库·sql