网站首页 > 技术文章 正文
执行计划执行计划是一条sql语句在ORACLE中的执行过程或访问路径的描述。即对一个sql语句,从执行计划可以看出oracle完成任务的详细方案。如果要分析某条SQL的性能问题,通常我们要先看SQL的执行计划,看看SQL的每一步执行是否存在问题。 看懂执行计划也就成了SQL优化的先决条件。 通过执行计划定位性能问题,定位后就通过建立索引、修改sql等解决问题。相关概念-单表访问路径
- TABLE ACESS FULL 全表扫描:没有建索引或者没有走上索引, 在较大的表上非常容易出现性能问题,应该尽量避免。
- index range scan 索引范围扫描 :走非唯一索引,或者是唯一索引使用了range操作(< > between等)
- index unique scan 索引唯一扫描:可以定位到单个ROWID。如果存在UNIQUE 或PRIMARY KEY 约束,就可以走索引唯一扫描
- index skip scan 索引跳跃扫描 :往往是走组合索引,但where条件中没有包括组合索引中所有的列
- index full scan 索引全扫描
- index fast full scan 索引快速全扫描
相关概念-表的连接方式
- nestLoop 嵌套连接:可以理解成两个嵌套的for循环,嵌套连接适合于返回少量数据,并且内部表关联字段上存在索引,外部表很小或者走索引后返回很少数据。成本约等于N次索引(N为外部表返回的记录数)
- hash join:
总成本为两张表单表访问路径的总成本!即使不存在索引,也就是两张表的全扫,与记录数无关。因此Hash连接适合返回大量数据,不要求表关联字段存在索引,Hash连接用在返回少量数据上很吃亏
执行计划的解读
- 对同一凹层,先上后下执行
- 对不同凹层,先里后外执行
如何查看sql语句的执行计划
- 直接解析SQL语句.
Explain plan for XXX;
Select * from table(dbms_xplan.display); - 根据SQL_ID查询,
select * from table
(dbms_xplan.display_cursor('&sql_id',0,
'allstats last')); - 从视图v$sql_plan 中获取。
- sqplus中可以使用set autotrace on,自动获取执行计划和统计信息
猜你喜欢
- 2024-10-17 oracle数据库设计总结|三大范式 oracle数据库设计规范
- 2024-10-17 数据库(Oracle)序列(Sequence)的基本使用
- 2024-10-17 oracle日常巡检--检查数据库安全 oracle问题排查
- 2024-10-17 [Oracle数据库] Oracle事务和常用数据对象
- 2024-10-17 SQL FOREIGN KEY 约束 sql语句的约束条件
- 2024-10-17 oracle每天做巡检时怎么检查数据库安全呢?
- 2024-10-17 Oracle与其他数据库的区别 oracle数据库和mysql区别
- 2024-10-17 Oracle项目管理系统之进度控制 oracle 项目管理软件
- 2024-10-17 一文搞懂Oracle 0 至 6 级锁(附案例详解)
- 2024-10-17 ORACLE 索引扫描 oracle 索引扫描 基数 计算公式
你 发表评论:
欢迎- 05-11FANUC修改前端目录教程
- 05-11前端分享-Set你不知道的事
- 05-11jq+ajax+bootstrap改了一个动态分页的表格
- 05-11千万级大表分页查询效率剧降,你会怎么办?
- 05-11Elasticsearch深度分页
- 05-11如何写一个简单的分页
- 05-11手速太快引发分页翻车?前端竞态陷阱揭秘
- 05-11「linux」Socket缓存是如何影响TCP性能的?
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端md5加密 (49)
- 前端路由 (55)
- 前端数组 (65)
- 前端定时器 (47)
- 前端懒加载 (45)
- 前端接口 (46)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle约束 (46)
- oracle 中文 (51)
- oracle链接 (47)
- oracle的函数 (57)
- mac oracle (47)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)