由于存储过程及触发器引用ORACLE动态视图v$session编译不通过而执行时报错ORA-04098

    今天遇见一个很神奇的问题,ERP合同系统需要记录登录oracle数据库的用户名、IP地址、登录时间、登录客户端类型记录信息,需要创建个触发器,
在触发器中需要查询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 ;
但是,这个存储过程在编译的时候报错如下所示:
具体定位到一个Oracle数据库系统视图v$session,如下所示:

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

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

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

请使用浏览器的分享功能分享到微信等