设为首页 收藏本站
查看: 1382|回复: 0

[经验分享] 疑问:【动态性能视图】v$fixed_table和v$fixed_view_definition

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2015-11-9 12:03:54 | 显示全部楼层 |阅读模式
v$fixed_table这个视图中存储的是oracle的基表,可是当我们desc的时候会发现,里面有个字段是type,如下:SYS@ORA10G>desc v$fixed_table Name           Null?    Type ————– ——– ———————- NAME                    VARCHAR2(30) OBJECT_ID               NUMBER TYPE                    VARCHAR2(5) TABLE_NUM               NUMBER SYS@ORA10G>SYS@ORA10G>select type,count(*) from v$fixed_table group by type; TYPE    COUNT(*)—– ———-TABLE        613VIEW         770 SYS@ORA10G>我们会发现,类型有两种,一种是table一种是view,v$fixed_table从字面理解是“固定表”,既然是表,怎么会有视图呢,查看官方文档得之,里面不但有表还有动态性能视图,此时吾大怒,动态性能视图多了个什么呀,这个视图明明叫fixed_table“固定表”,也就是不允许“动”的表,为什么把动态性能视图放进行。看来有必要 刨一 刨动态性能视图。网上有好多朋友也都刨过动态性能视图的根,我在此也小刨一下。刨谁呢?随便吧。SYS@ORA10G>select * from v$fixed_table where type=upper(‘view’) and rownum<=2; NAME                            OBJECT_ID TYPE   TABLE_NUM—————————— ———- —– ———-GV$WAITSTAT                    4294951371 VIEW       65537V$WAITSTAT                     4294950915 VIEW       65537 SYS@ORA10G>这里我选了2个,一个是v$开头的一个是gv$开头的,gv$多用于RAC环境,在单实例的数据库中,v$和gv$的内容是一样的,不过,他们的关系是怎么样的,还需要刨了之后才知道。那就选它了V$WAITSTAT。  1)查看V$WAITSTAT这个动态性能视图的创建脚本,我们采用dbms_metadata.get_ddl这个函数包,将它的脚本刨出来。SYS@ORA11GR2>select dbms_metadata.get_ddl(upper(‘view’),upper(‘v$waitstat’),upper(‘sys’)) from dual;ERROR:ORA-31603: object “V$WAITSTAT” of type VIEW not found in schema “SYS”ORA-06512: at “SYS.DBMS_SYS_ERROR”, line 105ORA-06512: at “SYS.DBMS_METADATA”, line 3912ORA-06512: at “SYS.DBMS_METADATA”, line 5678ORA-06512: at line 1   no rows selected SYS@ORA11GR2> 2)从错误中我们得知,在sys下的视图中没有找到V$WAITSTAT,看来V$WAITSTAT是混进视图的队伍中的,既然如此,我们从all_objects这个视图中找找看,看看它到底是什么?SYS@ORA11GR2>col object_name for a15SYS@ORA11GR2>col object_type for a15SYS@ORA11GR2>col owner for a15SYS@ORA11GR2>select object_name,object_type,owner from all_objects where object_name=upper(‘v$waitstat’); OBJECT_NAME     OBJECT_TYPE     OWNER————— ————— —————V$WAITSTAT      SYNONYM         PUBLIC SYS@ORA11GR2> 3)原来如此,原来v$waitstat是个同义词,那么我就按照同义词,并且它的owner是public往下刨吧。SYS@ORA11GR2>select dbms_metadata.get_ddl(upper(‘synonym’),upper(‘v$waitstat’),upper(‘public’)) from dual; DBMS_METADATA.GET_DDL(UPPER(‘SYNONYM’),UPPER(‘V$WAITSTAT’),UPPER(‘PUBLIC’))————————————————————-   CREATE OR REPLACE PUBLIC SYNONYM “V$WAITSTAT” FOR “SYS”.”V_$WAITSTAT”   SYS@ORA11GR2> 4)嗯,刨出来了,v$waitstat原来是v_$waitstat的同义词,既然找到了,那么就继续刨吧SYS@ORA11GR2>select object_name,object_type,owner from all_objects where object_name=upper(‘v_$waitstat’); OBJECT_NAME     OBJECT_TYPE     OWNER————— ————— —————V_$WAITSTAT     VIEW            SYS SYS@ORA11GR2> 5)通过上面的查询,v_$waitstat确实是一个视图并且属于sys,我们继续刨SYS@ORA11GR2>set long 99999SYS@ORA11GR2>set pagesize 300SYS@ORA11GR2>select dbms_metadata.get_ddl(upper(‘view’),upper(‘v_$waitstat’),upper(‘sys’)) from dual; DBMS_METADATA.GET_DDL(UPPER(‘VIEW’),UPPER(‘V_$WAITSTAT’),UPPER(‘SYS’))———————————————————————   CREATE OR REPLACE FORCE VIEW “SYS”.”V_$WAITSTAT” (“CLASS”, “COUNT”, “TIME”) AS   select “CLASS”,”COUNT”,”TIME” from v$waitstat   SYS@ORA11GR2> 6)此时我们发现v_$waitstat这个视图是跟据v$waitstat创建的,感觉是个圈,又绕回去了。其实则不然,这一步v$waitstat就是v$fixed_table中的那个动态性能视图。我们在查看官方文档的时候,在Reference这本书中查找v$fixed_table的时候,你会发现v$fixed_table下面有个视图,叫v$fixed_view_definition(字面翻译,固定视图定义)。既然我们在v$fixed_table中找到的视图,那么这个视图的定义,估计在v$fixed_view_definition里面有,我们查询一下SYS@ORA11GR2>select view_definition from v$fixed_view_definition where view_name=upper(‘v$waitstat’); VIEW_DEFINITION————————————————————————-select class,count,time from gv$waitstat where inst_id = USERENV(‘Instance’) SYS@ORA11GR2> 7)我们再观察,发现v$waitstat这个视图的定义是来源于gv$waitstat(gv$waitstat这个动态性能视图主要是用于RAC环境),我们之前想刨那个视图的时候,查出来两个,就包括gv$waitstat,也就是说,gv$waitstat在v$fixed_view_definition中也有定义信息,查之SYS@ORA11GR2>select view_definition from v$fixed_view_definition where view_name=upper(‘gv$waitstat’); VIEW_DEFINITION————————————————————————–select inst_id,decode(indx,1,’data block’,2,’sort block’,3,’save undo block’, 4,‘segment header’,5,’save undo header’,6,’free list’,7,’extent map’, 8,’1st level bmb’,9,’2nd level bmb’,10,’3rd level bmb’, 11,’bitmap block’,12,’bitmap index block’,13,’file header block’,14,’unused’, 15,’system undo header’,16,’system undo block’, 17,’undo header’,18,’undo block’), count,time from x$kcbwait where indx!=0 SYS@ORA11GR2>哦了,看到底儿了,基表是x$kcbwait  小结:1)X$开头oracle的基表(sys)-> gv$开头的固定视图(sys)->v$开头的固定视图(sys)->v_$开头的视图(sys)->v$开头的同义词(pubilc) 2)我们在sys用户下查询动态性能视图的时候,查的应该就是自己的动态性能视图,如果在其他有dba角色的用户下查询的话,应该查的是public用户下的同义词。 3)动态性能视图为什么是固定视图?因为这个视图是不允许修改的。动态性能视图的结构信息在v$fixed_view_definition中定义。4)v$fixed_table和v$fixed_view_definition也都是动态性能视图。有兴趣,大家可以刨刨。By gadmin ·LIBRARY ·


参考:
疑问:固定表是什么

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-137003-1-1.html 上篇帖子: OCM_Session7_4_修改内核配置文件/etc/sysctl.conf 下篇帖子: OCM_session0手动建库实验
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表