Oracle中如何获取v$latch数据源实验

65次阅读
没有评论

共计 3091 个字符,预计需要花费 8 分钟才能阅读完成。

这篇文章主要介绍了 Oracle 中如何获取 v$latch 数据源实验,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让丸趣 TV 小编带着大家一起了解一下。

实验环境:Oracle Rac 11.2.0.3

首先获取 v$latch 的定义:
通过 PL/SQL 或者 get ddl 等常规途径只能获取到 v_$latch 相关的视图信息。
需要通过特殊方法获取 v$latch 的 ddl
可以通过 set autotrace traceonly 开启状态下执行 select * from v$latch; 得知表的数据来源是 x$kslltr,结果如下:
—————————————————————————–
| Id  | Operation  | Name  | Rows  | Bytes | Cost (%CPU)| Time  |
—————————————————————————–
|  0 | SELECT STATEMENT |  |  1 |  352 |  0  (0)| 00:00:01 |
|*  1 |  FIXED TABLE FULL| X$KSLLTR |  1 |  352 |  0  (0)| 00:00:01 |

通过 sql_trace 的方式因为版本问题,trace 的输出结构略有不同,在 11.2.0.4.5 中可以获取的 ddl,但是在我的实验环境中无法获取,方法如下
alter session set sql_trace=true;
select * from v$latch;
alter session set sql_trace=false;
select * from v$diag_info where name= Default Trace File
tkprof xxxx.trc

通过 10053trace 的方式获取到 v$latch 的具体底层数据来源,方法如下
alter session set events 10053 trace name context forever,level 1
select * from v$latch;
alter session set events 10053 trace name context off
select * from v$diag_info where name= Default Trace File

vim /u01/app/oracle/diag/rdbms/irac/IRAC1/trace/IRAC1_ora_16791.trc
注意!请不要使用 sys 用户做 10053 trace,你是得不到结果的。
得到如下结果,从输出可以看出,最终转换的 sql 语句如下;
Final query after transformations:******* UNPARSED QUERY IS *******
SELECT LT . KSLLTADDR ADDR , LT . KSLLTNUM LATCH# , LT . KSLLTLVL LEVEL# , LT . KSLLTNAM NAME , LT . KSLLTHSH HASH , LT . KSLLTWGT GETS , LT . KSLLTWFF MISSES , LT . KSLLTWSL SLEEPS , LT . KSLLTNGT IMMEDIATE_GETS , LT . KSLLTNFA IMMEDIATE_MISSES , LT . KSLLTWKC WAITERS_WOKEN , LT . KSLLTWTH WAITS_HOLDING_LATCH , LT . KSLLTHST0 SPIN_GETS , LT . KSLLTHST1 SLEEP1 , LT . KSLLTHST2 SLEEP2 , LT . KSLLTHST3 SLEEP3 , LT . KSLLTHST4 SLEEP4 , LT . KSLLTHST5 SLEEP5 , LT . KSLLTHST6 SLEEP6 , LT . KSLLTHST7 SLEEP7 , LT . KSLLTHST8 SLEEP8 , LT . KSLLTHST9 SLEEP9 , LT . KSLLTHST10 SLEEP10 , LT . KSLLTHST11 SLEEP11 , LT . KSLLTWTT WAIT_TIME FROM SYS. X$KSLLTR LT WHERE LT . INST_ID =USERENV(INSTANCE)
kkoqbc: optimizing query block SEL$88122447 (#0)
从而得到 v$latch 的底层数据来源。

当然,如果每次想看到官方文档中没有记载的视图就去做一个 10053trace,实在麻烦,可以使用如下方式,简单方便的查询到视图的数据源:
SQL SELECT * FROM v$fixed_view_definition WHERE view_name = V$LATCH

VIEW_NAME
——————————————————————————–
VIEW_DEFINITION
——————————————————————————–
V$LATCH
select addr,latch#,level#,name,hash,gets,misses,sleeps,immediate_gets, immediate
_misses,waiters_woken,waits_holding_latch,spin_gets, sleep1,sleep2,sleep3,sleep4
,sleep5,sleep6,sleep7,sleep8,sleep9, sleep10,sleep11,wait_time from gv$latch whe
re inst_id = USERENV(Instance)

SQL SELECT * FROM v$fixed_view_definition WHERE view_name = GV$LATCH

VIEW_NAME
——————————————————————————–
VIEW_DEFINITION
——————————————————————————–
GV$LATCH
select lt.inst_id,lt.kslltaddr,lt.kslltnum,lt.kslltlvl,lt.kslltnam,  lt.ks
llthsh,lt.kslltwgt,lt.kslltwff,  lt.kslltwsl,lt.kslltngt,lt.kslltnfa,lt.ks
lltwkc,  lt.kslltwth,lt.ksllthst0,lt.ksllthst1,lt.ksllthst2,  lt.ksl
lthst3,lt.ksllthst4,lt.ksllthst5,lt.ksllthst6,lt.ksllthst7,  lt.ksllthst8,
lt.ksllthst9,lt.ksllthst10, lt.ksllthst11, lt.kslltwtt from x$kslltr lt

SQL

感谢你能够认真阅读完这篇文章,希望丸趣 TV 小编分享的“Oracle 中如何获取 v$latch 数据源实验”这篇文章对大家有帮助,同时也希望大家多多支持丸趣 TV,关注丸趣 TV 行业资讯频道,更多相关知识等着你来学习!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-20发表,共计3091字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)