在触发器中需要查询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编译无法通过的触发器就可以成功编译了: