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)