前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >【DB应用】SQL执行计划简述

【DB应用】SQL执行计划简述

作者头像
Luga Lee
发布2022-03-25 14:10:05
5001
发布2022-03-25 14:10:05
举报
文章被收录于专栏:架构驿站

SQL查询语句的性能从一定程度上影响整个数据库的性能。很多情况下,数据库性能的低下差不多都是不良SQL语句所引起。而SQL语句的执行 计划则决定了SQL语句将会采用何种方式从数据库提取数据并返回给客户端,本文描述的将是如何通过EXPLAIN PLAN 获取SQL语句执行计划来获 取SQL语句的执行计划。

一、获取SQL语句执行计划的方式

  • 使用explain plan 将执行计划加载到表plan_table,然后查询该表来获取预估的执行计划
  • 查询动态性能视图vsql_plan,vsql_plan_statistics,v
  • 查询自动工作量资料库(Automatic Workload Repository)或查询Statspack,即从资料库中获取执行计划
  • 启用执行计划跟踪功能,即autotrace功能
  • 使用PL/SQL Developer提供的获取执行计划方法
  • 使用Toad工具来获取执行计划

二、explain plan工作实质、前提及操作方法 1. 工作实质 将SQL语句预估的执行计划加载到表plan_table,是对表plan_table 执行了DML操作,故不会执行隐式提交 可以对select,insert,update,merge,delete,create table, create index,alter index等加载执行计划到plan_table

2. 前提条件 需要先创建plan_table,创建方法:@?/rdbms/admin/utlxplan 对当前的SQL语句有执行权限以及对依赖的对象有相应操作的权限

3. 使用方法: explain plan for select * from scott.emp where ename='SCOTT'; --未设置标记位 explain plan set statement_id='TEST' for select * from scott.emp where ename='SCOTT' --设置标记位为TEST

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2015-03-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 架构驿站 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
数据库
云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档