Oracle11g触发器调试记录Error:PLS-00201:identifier'SYS.DBMS_SYST
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了Oracle11g触发器调试记录Error:PLS-00201:identifier'SYS.DBMS_SYST,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2776字,纯文字阅读大概需要4分钟。
内容图文
![Oracle11g触发器调试记录Error:PLS-00201:identifier](/upload/InfoBanner/zyjiaocheng/562/9a520e03c12045c3b9dfcd01d84e2ce3.jpg)
Oracle 11g 触发器调试记录Error: PLS-00201: identifier
1,触发器内容如下
CREATE OR REPLACE TRIGGER"LOGON_DENIED_TO_ALERT"
AFTER servererror ON DATABASE
DECLARE
message VARCHAR2(168);
ip VARCHAR2(15);
v_os_user VARCHAR2(80);
v_module VARCHAR2(50);
v_action VARCHAR2(50);
v_pid VARCHAR2(10);
v_sid NUMBER;
v_program VARCHAR2(48);
BEGIN
IF(ora_is_servererror(1017)) THEN
-- get ip FOR remote connections :
IF upper(sys_context('userenv', 'network_protocol')) = 'TCP' THEN
ip := sys_context('userenv', 'ip_address');
END IF;
SELECT sid INTO v_sid FROM sys.v_$mystat WHERE rownum < 2;
SELECT p.spid, v.program
INTO v_pid, v_program
FROM v$process p, v$session v
WHERE p.addr = v.paddr
AND v.sid = v_sid;
v_os_user := sys_context('userenv', 'os_user');
dbms_application_info.read_module(v_module, v_action);
message := to_char(SYSDATE, 'YYYYMMDD HH24MISS') ||
' logon denied from ' || nvl(ip,'localhost') || ' ' ||
v_pid || ' ' || v_os_user || 'with ' || v_program || ' – ' ||
v_module || ' ' || v_action;
sys.dbms_system.ksdwrt(2, message);
ENDIF;
END;
2,执行报错信息:
Compilation errors for TRIGGERTIMDBA.LOGON_DENIED_TO_ALERT
Error: PL/SQL: ORA-00942: table or viewdoes not exist
Line: 20
Text: SELECT sid INTO v_sid FROMsys.v_$mystat WHERE rownum < 2;
Error: PL/SQL: SQL Statement ignored
Line: 20
Text: SELECT sid INTO v_sid FROMsys.v_$mystat WHERE rownum < 2;
Error: PL/SQL: ORA-00942: table or viewdoes not exist
Line: 23
Text: FROM v$process p, v$session v
Error: PL/SQL: SQL Statement ignored
Line: 21
Text: SELECT p.spid, v.program
Error: PLS-00201: identifier'SYS.DBMS_SYSTEM' must be declared
Line: 35
Text: sys.dbms_system.ksdwrt(2, message);
Error: PL/SQL: Statement ignored
Line: 35
Text: sys.dbms_system.ksdwrt(2, message);
解决办法
grant execute on sys.dbms_system to timdba;
3,再次执行还在报错:
Compilation errors for TRIGGER TIMDBA.LOGON_DENIED_TO_ALERT
Error: PL/SQL: ORA-00942: table or viewdoes not exist
Line: 20
Text: SELECT sid INTO v_sid FROMsys.v_$mystat WHERE rownum < 2;
Error: PL/SQL: SQL Statement ignored
Line: 20
Text: SELECT sid INTO v_sid FROMsys.v_$mystat WHERE rownum < 2;
Error: PL/SQL: ORA-00942: table or viewdoes not exist
Line: 23
Text: FROM v$process p, v$session v
Error: PL/SQL: SQL Statement ignored
Line: 21
Text: SELECT p.spid, v.program
解决办法:
grant select on sys.v_$mystat to timdba;
4,再次调试报错信息3
Compilation errors for TRIGGERTIMDBA.LOGON_DENIED_TO_ALERT
Error: PL/SQL: ORA-00942: table or viewdoes not exist
Line: 23
Text: FROM v$process p, v$session v
Error: PL/SQL: SQL Statement ignored
Line: 21
Text: SELECT p.spid, v.program
解决办法:
grant select on sys.v_$process to timdba;
grant select on sys.v_$session to timdba;
本文永久更新链接地址:
内容总结
以上是互联网集市为您收集整理的Oracle11g触发器调试记录Error:PLS-00201:identifier'SYS.DBMS_SYST全部内容,希望文章能够帮你解决Oracle11g触发器调试记录Error:PLS-00201:identifier'SYS.DBMS_SYST所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。