今天遇见一个很神奇的问题,ERP合同系统需要记录登录oracle数据库的用户名、IP地址、登录时间、登录客户端类型记录信息,需要创建个触发器,
在触发器中需要查询v$session视图,如下所示:
在触发器中需要查询v$session视图,如下所示:
create or replace trigger EPMFRAMEWORK.PRF_OP_LOG
before delete or update on EPMFRAMEWORK.PRF_PROJECT_INFO_T
for each row
begin
insert into EPMFRAMEWORK.MID_PRF_TT_LOG
select sid,
username,
program,
machine,
sys_context('userenv','ip_address') ,
sysdate
from v$session
where audsid = userenv('sessionid');
end ;
但是,这个存储过程在编译的时候报错如下所示:
before delete or update on EPMFRAMEWORK.PRF_PROJECT_INFO_T
for each row
begin
insert into EPMFRAMEWORK.MID_PRF_TT_LOG
select sid,
username,
program,
machine,
sys_context('userenv','ip_address') ,
sysdate
from v$session
where audsid = userenv('sessionid');
end ;
但是,这个存储过程在编译的时候报错如下所示:
![](http://img.blog.itpub.net/blog/attachment/201512/25/29357786_14510082377zD2.png?x-oss-process=style/bb)
具体定位到一个Oracle数据库系统视图v$session,如下所示:
但是,该用户在sqlplus中单独执行涉及的v$session SQL语句是没问题的,如下所示:
然而,出现这种问题的原因还是,用户对动态视图的查询权限不足造成的,处理方法如下:
然后,再编译之前由于引用v$session编译无法通过的触发器就可以成功编译了:
![](http://img.blog.itpub.net/blog/attachment/201512/25/29357786_1451008305t56z.png?x-oss-process=style/bb)
但是,该用户在sqlplus中单独执行涉及的v$session SQL语句是没问题的,如下所示:
![](http://img.blog.itpub.net/blog/attachment/201512/25/29357786_1451008609gQCC.jpg?x-oss-process=style/bb)
然而,出现这种问题的原因还是,用户对动态视图的查询权限不足造成的,处理方法如下:
![](http://img.blog.itpub.net/blog/attachment/201512/25/29357786_14510084173175.jpg?x-oss-process=style/bb)
然后,再编译之前由于引用v$session编译无法通过的触发器就可以成功编译了:
![](http://img.blog.itpub.net/blog/attachment/201512/25/29357786_1451008490bP76.jpg?x-oss-process=style/bb)
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29357786/viewspace-1960977/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/29357786/viewspace-1960977/