今天遇见一个很神奇的问题,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 ;
但是,这个存储过程在编译的时候报错如下所示:

具体定位到一个Oracle数据库系统视图v$session,如下所示:
但是,该用户在sqlplus中单独执行涉及的v$session SQL语句是没问题的,如下所示:
然而,出现这种问题的原因还是,用户对动态视图的查询权限不足造成的,处理方法如下:
然后,再编译之前由于引用v$session编译无法通过的触发器就可以成功编译了:

但是,该用户在sqlplus中单独执行涉及的v$session SQL语句是没问题的,如下所示:

然而,出现这种问题的原因还是,用户对动态视图的查询权限不足造成的,处理方法如下:

然后,再编译之前由于引用v$session编译无法通过的触发器就可以成功编译了:

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/29357786/viewspace-1960977/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/29357786/viewspace-1960977/