SQL_TRACE

set linesize 10000;
set pagesize 20000;
set serveroutput on;
alter session set sql_trace=true;
select count(*) from firefox;
alter session set sql_trace=false; --查看sql_trace trace file
select * from v$diag_info where name like 'Default%';
select sid,serial# from v$session ; variable x number;
exec :x:=1;
alter session set events '10046 trace name context forever,level 12';
select count(*) from firefox where object_id=:x;
alter session set events '10046 trace name context off';
select object_name from dba_objects where object_id=426 or object_id=427 SQL> select * from aux_stats$;
收集系统信息
exec dbms_stats.gather_system_stats(gathering_mode=>'start');
alter system flush_cache;
select count(*) from fire_t01;
select * from aux_stats$; 初始化参数;
db_file_multiblock_read_count
查看数据表一共有多少个块;
select blocks from user_tables where table_name='FIREFOX'; set autotrace on;
SELECT * FROM FIREFOX; SELECT /*+ blocks/k=cost */ 1029/10.4 from dual; 查看数据块大小
show parameter db_block_size; select * from sys.aux_stats$;
SYSSTATS_MAIN IOSEEKTIM 10
SYSSTATS_MAIN IOTFRSPEED 4096
SYSSTATS_MAIN CPUSPEEDNW 2657.0122 #单块读的时间
sreadtim = IOSEEKTIM+(size of one block/IOTFRSPEED).
=10+(8192/4096)=12
#多块数据块读取的时间
mreadtim=IOSEEKTIM+(MBRC * SIZE OF one block) / IOTFRSPEED)
=10+((16*8192)/4096)=42
io_cost=(1046(blocks)/16)*(42/12)=232.75
cpu_cost=cpu_cost=cpucycles/(cpuspeed*sreadtim)
=116192792/(2657.0122*12*1000)=4.48
cost=io_cost+cpu_cost = 232.75 + 4.48 =
如何查看cpucycles:PLAN_TABLE、PLAN_TABLE$; create table firefox1 as select * from firefox where rownum<100;
create index idx_firefox on firefox(object_id);
create index idx_firefox1 on firefox1(object_id); begin
dbms_stats.gather_table_stats(
user,
'firefox',
cascade => true,
estimate_percent => null,
method_opt =>'for all columns size 1'
);
end;
/ begin
dbms_stats.gather_table_stats(
user,
'firefox1',
cascade => true,
estimate_percent => null, --完全精确地分析;
method_opt =>'for all columns size 1'
);
end;
/ alter session set events '10053 trace name context forever,level 12';
select * from firefox,firefox1 where firefox.object_id = firefox1.object_id;
alter session set events '10053 trace name context off';
select * from v$diag_info where name like 'Default%'; 对SGA区的动态调整;
SQL> show sga; 网络连接 --session &processes;
SQL> select username,paddr from v$session where username is not null; USERNAME PADDR
------------------------------ ----------------
SYS 00000000F04DAE60
SYS 00000000F04DAE60
C##SCOTT 00000000F04DBEA0 select addr from v$process where background is null and addr='00000000F04DAE60';
select * from v$process where background is null and addr='00000000F04DAE60'; set autotrace on stat;
select username,paddr from v$session where username is not null;
select addr from v$process where background is null and addr='00000000F04DAE60'; CBO计算成本时索引的权重修正值.
show parameter OPTIMIZER_INDEX_COST_ADJ;
alter session set OPTIMIZER_INDEX_COST_ADJ=10;
优化器--optimizer_mode
first_rows [1|10|100|1000]
first
优化器--optimizer_dynamic_sampling
动态采样的级别0to10
默认值(9i 1, >= 10g 2) 查看当前sql/plus 的SID
SELECT sid, serial# FROM v$session WHERE audsid=SYS_CONTEXT('USERENV','SESSIONID');
select a.name,b.value from v$sesstat b.v$statname a where a.static#=b.statistic# and a.name ='CPU used by this session' and sid=69; 显示各种文件的I/O统计信息
- 数据文件,临时文件,控制文件,日志文件,归档文件...
select file_no,filetype_name,LARGE_READ_MEGABYTES,SMALL_READ_MEGABYTES,SMALL_SYNC_READ_LATENCY from v$iostat_file;
对象--v$segstat
获得某对象的各类统计信息;
select * from v$segstat where obj#=79605 and statistic_name='physical_reads';

Oracle DBA学习篇之SQL_TRACE的更多相关文章

  1. Oracle DBA 学习总结

    对于学习Oracle 数据库,应该先要了解Oracle 的框架.它有物理结构(由控制文件.数据文件.重做日志文件.参数文件.归档文件.密码文件组成) ,逻辑结构(表空间.段.区.块),内存分配( SG ...

  2. oracle开发学习篇之集合函数

    集合函数; declare type list_nested ) not null; v_all list_nested := list_nested('changan','hubei','shang ...

  3. oracle开发学习篇之集合运算符以及集合异常捕获

    --取出集合;长度 declare type list_nested ) not null; v_all list_nested := list_nested('a','b','c','d','c', ...

  4. Oracle DBA的学习(笔记)

    1.软件任务分组:系统分析师.系统设计师.程序员.测试人员.开发dba.系统架构师.实施人员. 2.常用设计图:活动图.用例图.类图.序列图. 2010-9-15(dba学习) 1.1 Oracle产 ...

  5. Oracle RMAN 学习:演练进阶篇

    Oracle RMAN 学习:演练进阶篇 5 Rman备份演练进阶篇 5.1 是否选择增量备份 Backup命令生成的备份集中只备份了那些使用了的数据块,备份集实际大小已经较目标数据库的数据文件小了很 ...

  6. Oracle DBA面试突击题

    一份ORACLE DBA面试题 一:SQL tuning 类 1:列举几种表连接方式 答: Oracle的多表连接算法有Nest Loop.Sort Merge和Hash Join三大类,每一类又可以 ...

  7. oracle Dba之路

    如何快速的成为一个合格的 DBA? 2010年11月03日 11:25:00 阅读数:584 原文来自:http://topic.csdn.net/u/20101031/21/A78B2EA1-6F2 ...

  8. Oracle基础学习笔记

    Oracle基础学习笔记 最近找到一份实习工作,有点头疼的是,有阶段性考核,这...,实际想想看,大学期间只学过数据库原理,并没有针对某一数据库管理系统而系统的学习,这正好是一个机会,于是乎用了三天时 ...

  9. Asp.Net MVC4 + Oracle + EasyUI 学习 序章

    Asp.Net MVC4 + Oracle + EasyUI  序章 -- 新建微软实例 本文链接:http://www.cnblogs.com/likeli/p/4233387.html 1.  简 ...

随机推荐

  1. c++语言知识点汇总

    c++ primer version-5 的整理 section 1: 内置类型和自定义类型: main函数的返回值:指示状态.0:成功:1:系统定义. unix和win系统中,执行完程序可以使用ec ...

  2. github 优秀的开源项目

    https://github.com/wlcaption/AndroidMarket---- 这是手机应用商店,包含应用的下载,用户中心等内容 https://github.com/wlcaption ...

  3. 用sklearn计算卡方检验P值

    情形: 1. 对于一批分类变量,我们通常要评价两两之间的相关程度. 2. 因变量是分类变量,衡量其他分类变量和因变量的相关性高低. 来源:https://blog.csdn.net/snowdropt ...

  4. Python 内置装饰器

    内置的装饰器 ​ 内置的装饰器和普通的装饰器原理是一样的,只不过返回的不是函数,而是类对象,所以更难理解一些. @property ​ 在了解这个装饰器前,你需要知道在不使用装饰器怎么写一个属性. d ...

  5. java基础42 File类的构造函数及其方法

    本文知识点(目录): 1.IO流(Input Output)    2.IO流技术的运用场景    3.File类的构造函数(方法)    4.File类的一些常用方法    5.实例(解析File类 ...

  6. 牛客红包OI赛 B 小可爱序列

    Description 链接:https://ac.nowcoder.com/acm/contest/224/B 来源:牛客网 "我愿意舍弃一切,以想念你,终此一生." " ...

  7. 洛谷P2018消息传递

    传送门啦 这个树形dp就没那么简单了,运用了一下贪心的思想 不同的排序方法对应着不同的转移方程,如果我们用 $ f[x] = max(f[x] , b[i] +cnt - i + 1) $ 来进行转移 ...

  8. 网络协议之UDP

    前言 TCP协议在不可靠的网络环境上提供了可靠的通信通道,隐藏了大量的底层细节,使应用程序更加简洁.但有些应用并不需要这么高的可靠性,并不需要按序交付,而且TCP为了提高可靠性也增加了延时,在某些对延 ...

  9. Codeforces 552C Vanya and Scales(进制转换+思维)

    题目链接:http://codeforces.com/problemset/problem/552/C 题目大意:有101个砝码重量为w^0,w^1,....,w^100和一个重量为m的物体,问能否在 ...

  10. HDU 4763 Theme Section(KMP+枚举公共前后缀)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4763 题目大意: 给你一个字符串s,存在一个子串E同时出现在前缀.中间.后缀,即EAEBE这种模式,A ...