Oracle的buffer cache是SGA的一个重要组成部分,因此当遇到并发访问时,都需要通过锁机制来保护()。这个锁就是buffer pin。
如果要读一个buffer, 先要获得共享的buffer pin锁。写则要获取独占的buffer pin锁。
这里buffer pin锁就有了两种模式,一种是S(共享模式),另外则是X(排他模式或独占模式)。
等待事件 cursor: pin S是对于cache buffer的争用。
以下脚本可以构造出cursor: pin S的等待事件。
create table mytest(
id number,
name varchar2(100)
)
insert into mytest
select rownum,
lpad('a',
trunc(dbms_random.value * 100),
chr(trunc(dbms_random.value * 100)))
from dual
connect by rownum <= 100;
注意,表上没有任何索引。
同时,在不同会话中执行如下脚本:
declare
v_name mytest.name%type;
begin
for i in 1 .. 100000000 loop
begin
select name into v_name from mytest where id = i;
exception
when no_data_found then
null;
end;
end loop;
end;
/
此时,可以在v$session_wait视图中看到如下等待事件:
![](//img.blog.itpub.net/blog/attachment/201607/13/8520577_1468375773pAt3.png?x-oss-process=style/bb)
如果要读一个buffer, 先要获得共享的buffer pin锁。写则要获取独占的buffer pin锁。
这里buffer pin锁就有了两种模式,一种是S(共享模式),另外则是X(排他模式或独占模式)。
等待事件 cursor: pin S是对于cache buffer的争用。
以下脚本可以构造出cursor: pin S的等待事件。
create table mytest(
id number,
name varchar2(100)
)
insert into mytest
select rownum,
lpad('a',
trunc(dbms_random.value * 100),
chr(trunc(dbms_random.value * 100)))
from dual
connect by rownum <= 100;
注意,表上没有任何索引。
同时,在不同会话中执行如下脚本:
declare
v_name mytest.name%type;
begin
for i in 1 .. 100000000 loop
begin
select name into v_name from mytest where id = i;
exception
when no_data_found then
null;
end;
end loop;
end;
/
此时,可以在v$session_wait视图中看到如下等待事件:
![](http://img.blog.itpub.net/blog/attachment/201607/13/8520577_1468375773pAt3.png?x-oss-process=style/bb)
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/8520577/viewspace-2121938/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/8520577/viewspace-2121938/