- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
游标故障案例解析
游标的概念
游标是SQL的一个内存工作区,由系统或用户以变量的形式定义。游标的作用就是用于临时存储从数据库中提取的数据块。
在某些情况下,需要把数据从存放在磁盘的表中调到计算机内存中进行处理,最后将处理结果显示出来或最终写回数据库。这样数据处理的速度才会提高,否则频繁的磁盘数据交换会降低效率。
游标有两种类型:显式游标和隐式游标。
在前述程序中用到的SELECT...INTO...查询语句,一次只能从数据库中提取一行数据,对于这种形式的查询和DML操作,系统都会使用一个隐式游标。
但是如果要提取多行数据,就要由程序员定义一个显式游标,并通过与游标有关的语句进行处理。显式游标对应一个返回结果为多行多列的SELECT语句。
游标一旦打开,数据就从数据库中传送到游标变量中,然后应用程序再从游标变量中分解出需要的数据,并进行处理。
--隐式游标
如前所述,DML操作和单行SELECT语句会使用隐式游标,它们是:
插入操作:INSERT。
更新操作:UPDATE。
删除操作:DELETE。
单行查询操作:SELECT ... INTO ...。
当系统使用一个隐式游标时,可以通过隐式游标的属性来了解操作的状态和结果,进而控制程序的流程。
隐式游标可以使用名字SQL来访问,但要注意,通过SQL游标名总是只能访问前一个DML操作或单行SELECT操作的游标属性。所以通常在刚刚执行完操作之后,立即使用SQL游标名来访问属性。
游标的属性有四种,如下所示:
故障类型及解析
1.?cursor:pin S wait on X等待事件
原因分析:
A session waits for this event when it is requesting a shared mutex pin and another session is holding an exclusive mutex pin on the same cursor object.(当会话请求一个共享互斥锁引脚,而另一个会话持有同一个游标对象上的互斥锁引脚时,会话等待该事件。)
这个事件的出现受到很多因素的影响,在高并发的情况下:
sga自动管理,sga的频繁扩展和收缩。
过渡硬解析,造成library cache中的cursor object被频繁的reload。
bug。
案例分析一:
数据库bug原因引发cursor:pin S wait on X等待事件。
1)查看等待事件详情
--查看系统上现有的快照信息:
SQL?col mintime for?a30SQL?col maxtime for?a30SQL?select min(snap_id) minid, max(snap_id) maxid,??2 to_char(min(begin_interval_time),yyyy-mm-dd hh24:mi:ss) mintime,??3 to_char(max(end_interval_time),yyyy-mm-dd hh24:mi:ss) maxtime??4 from dba_hist_snapshot;
--根据快照信息,我们来查看一下对应的等待事件分类情况:
SQL 1??select?wait_class_id,wait_class, count(*) cnt??2??from?dba_hist_active_sess_history??3??where?snap_id between 78303?and 78472??4??group?by?wait_class_id, wait_class??5???* order by?3WAIT_CLASS_ID WAIT_CLASS CNT------------- -------------------- ----------???2723168908?Idle 2???4166625743?Administrative 6???2000153315?Nication 829???3290255840?Configuration 4128???4108307767?System I/O 9234???1893977003?Other 11043???3386400367?Commit 26802???1740759767?User I/O 28076???3875070507?Concurrency 888984
--查看具体的等待事件情况:
SQL select?event_id, event, count(*) cnt ??2??from?dba_hist_active_sess_history??3??wh
原创力文档


文档评论(0)