场景5 Performance Management
场景5 Performance Management
性能调优(不能重启数据库)
索引
资源管理器
性能优化
统计分析
SQL性能分析
SPM (SQL执行计划管理)
堆表 :数据存储无序
位图索引 :适合字段重复值高的,数据仓库环境下(适合OLAP/DSS环境),存储占用空间少, DML成本高, WHERE中与或操作效率高
eg :
select count(*) from customers where m_status = married and region in (‘central’, ‘west’);
eg :
su -oracle
sqlplus / as sysdba
set linesize 120
set pagesize 20
line on
timing on
sqlprompt ‘_user@_connect_identifier’
start up
alter user scott identified by tiger unlock;
conn scott/tiger
create table t1 (id number, color varchar2, pty number);
begin for i in 1..50000 loop insert into t1 values(1, blue’, 1000); end loop; commt; end; /
select count(*) from t1;
update t1 set color=‘red’ where id < 20001;
update t1 set color=‘green’ where id > 40000;
commit;
select distinct color from t1;
!clear
create tablespace indx datafile ‘/u01/app/oracle/prod/indx01.dbf’ size 100m;
create indext1_color_ind on t1(color) tablespace indx;
analyze table t1 compute statistics; (表分析)
analyze index t1_color_ind compute statistics;
select a.table_name, a.index_name, a.index_type, a.leef_blocks, b.height from user_indexes a.index_stats b where a.index_mane=b.index_name and a.index_name=’T1_COLOR_IND’;
col table_name for a10
col index_name for a10
@?sqlplus/
conn scott/tiger
set autrace trace
select count(*) from t1 where color=‘blue’;
set auto trace off
select * from t1 where id<10;
drop index t1_color_indx;
create bitmap index t1_color_indx on t1(color) tablespace indx;
analyze index t1_color_indx compute statistics;
analyze index t1_color_indx valudate structure;
select a.table_name, a.index_name, a.index_type, a.leef_blocks, b.height from user_indexes a.index_stats b where a.index_mane=b.index_name and a.index_name=’T1_COLOR_IND’;
set autostrade trace
select count(*) from t1 where color=‘red’;
set auto trace off
select * from t1 where id < 10;
update t1 set color = ‘blue’ where id = 1;
update t1 set color = ‘green’ where id = 2;(打开另一个会话)
rollback;
rollback;
set autotrace trace
select count(*) from t1 where color=‘red’ or color = ‘blue’;
su - oracle
|sql
e.g. : select rowid, ename, sal from emp;
rowid : 6 :object_id, 3 :file#, 6 :block, 3 : row#
复合压缩索引 :
全局hash索引 :
反向索引 :解决热块问题,不适合范围查询
平衡树索引(普通索引):适合字段基数大,重复值少,DML代价比较低,适合OLTP环境
经常用于select语句中,where语句中,排序的字段适合建立索引
表级共享锁 share lock
行级排他锁 exclusive lock
段级位图锁
eg :
show parameter cpu
show parameter resoure
eg 资源管理器的创建 :
官方文档 :administrator
SQL 语句执行的三个过程 :
parse解析 : 建立执行计划
execute执行 :
fetch取值从buffer cache里获取数据 :
硬解析 :三步
软解析 :
1. 在lib cache读取执行计划
2. execute plan
3. 从buffer cache读取数据块
LRU : 最近最少使用
eg :
alter system set result_cache_max_size=0;
show parameter result
alter system set result_cache_max_size=1536;(从0改为非0后,必须重启才能生效)
eg :
conn scott/tiger
select /*+ result_cache */ count(*) from emp;
set autotrace trace
r
r
1
show parameter result
alter system set result_cache_mode = force;
select /*+ result_cache */ count(*) from emp;
r
exec dbms_result_cache.flush;
r
r
select dbms_result_cache.status from dual;
shutdown immediate;
startup
select dbms_result_cache.status from dual;
show parameter result
alter system set result_cache_mode=manual;
conn scott/tiger
set autotrace trace
select count(*) from emp where empno=20;
select /*+ result_cache */ count(*) from emp where deptno=20;
exec dbms_result_cache.memory_report;
set serverout on
exec dbms_result_cache.memory_report;
eg :
select * from emp where deptno=:n;
结果缓存(官方文档 Performance Tuning Guide 7.6 Managing the server and client query cache)
统计分析 (官方文档 PL/SQL Package and Type Reference 或
SPA (SQL Performance Analyzer)
SQL性能优化分析
SPM(SQL Plan Management)
SQL执行计划管理
store outline 存储纲要
sql profile
hints 提示
稳定执行计划,根据访问对象的变化,实时调整新的计划
spm : sql执行计划管理
sql plan baseline : 执行计划基线(执行计划的集合)
eg :
show parameter optimizer
eg :
select * from tab;
create table emp1 select * from emp;
select * from emp1;
set autotrace on
select * from emp1 where empno=7788;
r
select sql_text, sql_id from v$sql where sql_text like ‘select * from emp%’; (查询sql id)
set serveroutput on
declare
`1_plans_loaded pls_integer;
begin
1_p;ans_loaded := DBMS_SPM.load_plans_from_cursor_cache(sql_id =>…);
DBMS_OUTPUT.put_line(‘Plans Loaded : || 1_plan_loaded);
end;
/
select sql_handle, plan_name, enabled, accepted from dba_sql_plan_baselines where sql_text like ‘%emp1%’ and sql_id not like ‘%dba%’ ;
create index
set autotrace on
select * from emp1 where empno = 7788;
场景5 Performance Management的更多相关文章
- 场景3 Data Management
场景3 Data Management 数据管理 性能优化 OLTP OLAP 物化视图 :表的快照 传输表空间 :异构平台的数据迁移 星型转换 :事实表 OLTP : 在线事务处理 1. trans ...
- Pinpoint是一个开源的 APM (Application Performance Management/应用性能管理)工具,用于基于java的大规模分布式系统,基于Google Dapper论文
Pinpoint是一个开源的 APM (Application Performance Management/应用性能管理)工具,用于基于java的大规模分布式系统,基于Google Dapper论文 ...
- puma vs passenger vs rainbows! vs unicorn vs thin 适用场景 及 performance
ruby的几个web server,按照开发活跃度.并发方案及要点.适用场景等分析puma vs passenger vs rainbows! vs unicorn vs thin. 1. thin: ...
- 应用性能管理(APM, Application Performance Management)
当下成熟的互联网公司都建立有从基础设施到应用程序的全方位监控系统,力求及时发现故障进行处理并为优化程序提供性能数据支持,降低整体运维成本.国内外商业的APM有Compuware.iMaster.博睿B ...
- 独立安装Oracle Hyperion Enterprise Performance Management 验证过程
在安装EPM的过程中,都是安装既定的操作手册进行,只是一个过程的重复,对自己安装不会留下深刻的印象.根据自己学习体会,制定安装步骤,去验证自己学习过程中的体会,加深学习印象,解决安装中遇到的问题,模仿 ...
- Thinking Clearly about Performance
http://queue.acm.org/detail.cfm?id=1854041 The July/August issue of acmqueue is out now acmqueue is ...
- Java Performance Optimization Tools and Techniques for Turbocharged Apps--reference
Java Performance Optimization by: Pierre-Hugues Charbonneau reference:http://refcardz.dzone.com/refc ...
- Magic Quadrant for Security Information and Event Management
https://www.gartner.com/doc/reprints?id=1-4LC8PAW&ct=171130&st=sb Summary Security and risk ...
- 一篇分析诊断被"hang"住数据库的资料(Oracle Performance Diagnostic Guide——Hang/Locking)
该资料已上传至本人QQ群空间,如需该资料,可到本人QQ群空间查找.下面贴表文本: Oracle Performance Diagnostic GuideHang/LockingVersion 3.1. ...
随机推荐
- RDCManager(远程登录工具)
1: 2: 3: 4: 5 6 写文不易,转载请注明出处:http://www.cnblogs.com/zszs/p/5662752.html
- CSS选择器--普通选择器
普通选择器: 1.标签选择器:使用标签选择器,所有的相同的标签都会被选中.(如:选择div所有的div都被选中.) 2.类选择器:如果一个元素设置了多个类选择器样式,那么这些类选择器都会被设置.但是如 ...
- 【腾讯云的1001种玩法】在腾讯云上创建您的SQL Cluster(5)
版权声明:本文由李斯达 原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/97264001482830465 来源:腾云阁 h ...
- LOL
当输入数据一样时,计算结果是一样的,但运行时间的差别很大.在算法正确的前提下,应该选择算法效率高的 嵌入式软件,BSP驱动,通信协议,上层应用软件. 多协议标签交换(MPLS)是一种用于快速数据包交换 ...
- RStudio相关
1.设置默认目录,tool-Global Options,设定后要重启RStudio才能生效2.Ctrl+l清屏控制台3.↑健.回忆前一条命令,↓健相反4.Ctrl+↑,查找相应前缀的历史记录5.创建 ...
- jquery实现on/off开关按钮
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8&qu ...
- 使用 Box2D 做一个 JansenWalker 机器人
在 Box2DFlash 的官网的首页有一个小 Demo,这个 Demo 中有11个例子,可以通过左右方向键查看不同的例子,里面的每个例子都非常有趣,但最让我感兴趣的,是其中一个叫 JansenWal ...
- 迷茫的it男,我该何去何从
从去年7月份毕业,一直到现在已经快一年了.准确的说,我已经是工作两年的人了.第一份工作是HIS工程人员,主要负责医院系统部署维护实施工作,当初之所以找实施,也是迫不得已,退而求其次的想法,当时还是在校 ...
- SQL Server数据库脚本备份与还原
use[master]go /*完整--备份* backup 备份 * disk='E:\USERDB.bak' 磁盘,备份文件存放的路径* name='user' 备份显示的文件名称,可随意修改* ...
- python 函数传递参数的多种方法
python中函数根据是否有返回值可以分为四种:无参数无返回值,无参数有返回值,有参数无返回值,有参数有返回值. Python中函数传递参数的形式主要有以下五种,分别为位置传递,关键字传递,默认值传递 ...