ORA-04098错误解决方法
数据库版本:8.1.5
平台:SOLARIS 5.7
背景:
用户建立了一个TRIGGER:
create or replace trigger ddl_deny
before create or alter or drop on database
declare
begin
insert into ddl_logs values(ora_dict_obj_owner,ora_dict_obj_name,sysdate);
exception
when no_data_found then
null;
end;
目的大概就是记录下所有的DDL操作,但TRIGGER建立有错误,发现:
11:30:08 system@ORA250>alter trigger ddl_deny disable;
alter trigger ddl_deny disable
*
ERROR 位于第 1 行:
ORA-04098: 触发器 'DDL_DENY' 无效且未通过重新验证
11:31:45 system@ORA250>drop trigger ddl_deny;
drop trigger ddl_deny
*
ERROR 位于第 1 行:
ORA-04098: 触发器 'DDL_DENY' 无效且未通过重新验证
此时触发器不能编译过去,也不能删除了,因为触发器本身里面定义了DDL操作的触发,产生ORA-04098: 触发器 'DDL_DENY' 无效且未通过重新验证。
解决方法:
1、首先查看用户的权限是否正确:
select owner, object_name, object_type, status from dba_objects where object_name = '<TRIGGER_NAME>';
12:42:38 system@ORA250>select owner, object_name, object_type, status from dba_o
bjects where object_name='DDL_DENY';
OWNER OBJECT_NAME OBJECT_TYPE STATUS
------------------------------------ --------------
SYSTEM DDL_DENY TRIGGER INVALID
发现用户权限没有问题。
2、接着设置诊断事件alter session set events='4098 trace name errorstack level 3';,查看trace文件的内容如下:
Dump file /db1/app/Oracle/admin/ora250/udump/ora250_ora_6834.trc
Oracle8i Enterprise Edition Release 8.1.5.0.0 - ProdUCtion
With the Partitioning and Java options
PL/SQL Release 8.1.5.0.0 - Production
ORACLE_HOME = /db1/app/oracle/product/8.1.5
System name: SunOS
Node name: db250
Release: 5.7
Version: Generic_106541-08
Machine: sun4u
Instance name: ora250
Redo thread mounted by this instance: 1
Oracle process number: 17
Unix process pid: 6834, image: oracle@db250 (TNS V1-V3)
*** SESSION ID30.829) 2004.11.17.20.53.38.000
*** 2004.11.17.20.53.38.000
ksedmp: internal or fatal error
ORA-04098: 触发器'DDL_DENY' 无效且未通过重新验证
Current SQL statement for this session:
alter trigger ddl_deny disable
----- Call Stack Trace -----
calling call entry argument values in hex
location type point (? means dubious value)
-------------------- -------- -------------------- ----------------------------
ksedmp()+160 CALL ksedst()+0 508 ? 1 ? FFBEB31C ?
FFBEADC0 ? FFBEADA4 ? 0 ?
ksddoa()+248 PTR_CALL 00000000 3 ? 0 ? 0 ? 16594FC ?
C0000025 ? 0 ?
ksdpcg()+212 CALL ksddoa()+0 16EB0AC ? 16E4C24 ? 3 ?
24939C ? 16EB0AC ? 16EB090 ?
ksdpec()+236 CALL ksdpcg()+0 1002 ? FFBEB8E4 ? 16E4C24 ?
0 ? 0 ? 0 ?
ksfpec()+136 CALL ksdpec()+0 1002 ? 165A800 ? 165A800 ?
7F3 ? 1659995 ? 16594FC ?
kgesev()+100 PTR_CALL 00000000 1659494 ? 1002 ? 262F80 ?
1002 ? 1 ? 0 ?
ksesec1()+48 CALL kgesev()+0 1659494 ? 16E8CA4 ? 1002 ?
1 ? FFBEBA60 ? 1 ?
kkttrex()+2112 CALL ksesec1()+0 1002 ? 1 ? 8 ? 8E859D26 ? 2 ?
2 ?
kktexeevt()+616 CALL kkttrex()+0 8E996A20 ? 8E973B48 ?
FFBEBAE4 ? 1659000 ?
8E859D6C ? 165E800 ?.....
发现是内部严重错误,其他看不出太多错误信息,于是想到采用隐含参数_system_trigger_enabled=false,在数据库启动的时候让所有触发器不起作用,然后删除。
数据库8.1.5的提示没这个参数,于是查询了一下:
14:28:32 system@ORA815>select ksppinm from x$ksppi where substr(ksppinm,1,1)='_'
and ksppinm like '%tri%' order by ksppinm;
KSPPINM
-------------------------------------------------------------------------------
_cleanup_rollback_entries
_distributed_lock_timeout
_distributed_recovery_connection_hold_time
_number_cached_attributes
_system_trig_enabled
发现8.1.5版本的参数是_system_trig_enabled,于是让用户在初始化参数文件中设置此参数为false,然后重启数据库,删除trigger,删除成功。
至此问题解决。
分享到:
相关推荐
ora-00604 错误 解决 方法 ora-00604 错误 解决 方法 ora-00604 错误 解决 方法 ora-00604 错误 解决 方法 ora-00604 错误 解决 方法ora-00604 错误 解决 方法
### 创建物化视图ORA-12014错误解决方法 #### 背景介绍 在Oracle数据库中,物化视图(Materialized View)是一种用于优化查询性能的重要工具。它预先计算并存储了复杂的查询结果,从而在实际查询时能够快速地返回...
### ORA-01033 错误解决方法 #### 概述 在数据库管理过程中,遇到诸如ORA-01033等错误代码是非常常见的。这些错误往往与数据库实例的状态、文件系统问题或是配置不当有关。ORA-01033 错误通常表示在启动或关闭...
这篇文章主要讲述了在Oracle 11g R2客户端尝试连接Oracle 19c服务端时,遇到了两个特定的错误:ORA-28040和ORA-01017,以及如何解决这些问题。 ORA-28040错误是因为客户端和数据库服务器在版本兼容性上存在不匹配。...
### Oracle 10g启动后报ORA-16038错误的解决方法 #### 错误概述 在启动Oracle 10g数据库时遇到ORA-16038错误,该错误通常与归档日志操作有关。具体错误信息为: ``` ORA-16038: log 1 sequence #230 cannot be ...
Oracle数据库发生ORA-04031错误原因浅析及处理 Oracle数据库是甲骨文公司提供的...本文通过对ORA-04031错误的分析和解决方法的介绍,旨在帮助读者更好地理解Oracle数据库中的ORA-04031错误,并提供了实用的解决方法。
但是,清除事件日志是最简单和有效的解决方法,能够快速解决ora-28056错误。 ora-28056错误的预防方法: 为了预防ora-28056错误,数据库管理员可以定期清除事件日志,确保事件日志不溢出。此外,数据库管理员也...
本文将针对这些错误的排查方法进行详细介绍,帮助用户理解问题的原因及解决策略。 ### 错误概述 #### ORA-39002: invalid operation 此错误表示执行的操作无效,可能是由于某些配置或环境设置不正确导致的。例如,...
虽然这不是直接解决ORA-01460错误的方法,但通过合理配置工具和环境,可以更高效地进行数据库管理和数据转换工作,间接降低错误发生的概率。 总之,面对ORA-01460错误,关键在于理解错误背后的逻辑,采取合适的数据...
### 三、错误解决步骤 解决上述错误的关键在于确保数据库实例能够成功启动并进入正常运行状态。以下是一些基本的解决步骤: 1. **检查数据库实例状态**:首先,通过SQL*Plus或其他数据库管理工具登录到数据库...
ORACLE8I数据库应用EXP工具时ORA-06553报错的解决方法 摘要:本文主要解决ORACLE 8I数据库应用EXP工具时ORA-06553报错的问题,分析出现问题的原因,并提供了正确的解决方法和措施。 知识点1:Oracle 8I数据库EXP...
用oracle数据库新建连接时遇到ora-12505,此问题解决后又出现ora-12519错误,郁闷的半天,经过一番折腾问题解决,下面小编把我的两种解决方案分享给大家,仅供参考。 解决方案一: 今天工作时在新建连接的时候遇到...
关于WIN10系统使用oracle instant client 时候提示ORA-01019错误的解决方案,本方案是配置好环境变量后依然提示ORA-01019错误的解决方案,内附本人制作测试的全过程说明
### ORA-01460 错误原因分析 ...通过以上步骤的检查和调整,通常可以解决大部分由ORA-01460错误引起的数据库操作问题。需要注意的是,在进行任何更改之前,最好先备份相关配置和数据,以免出现意外情况。
### ORA-12514错误解决办法 #### 错误概述 ORA-12514是Oracle数据库中常见的一个错误,全称为“TNS:listener does not currently know of service requested in connect descriptor”。该错误表明客户端尝试连接到...
通过以上方法,我们可以有效地解决ORA-29275错误,并提高Oracle数据库的整体稳定性和数据完整性。需要注意的是,在实际操作过程中,应当根据具体情况选择最适合的解决方案。例如,在某些情况下,调整字段长度可能是...
解决ORA-01145错误的方法如下: 1. **启用介质恢复**:对于需要进行离线操作的数据文件,首先应启用介质恢复。 2. **创建新的数据文件**:可以先创建一个新的数据文件来替换原有的数据文件,然后再执行离线操作。 3....
### Oracle 错误 ORA-00132 和 ORA-00214 解析及处理 #### 一、错误概述 在Oracle数据库管理过程中,遇到ORA-00132和ORA-00214这类错误时,往往意味着数据库配置或启动过程中出现了问题。下面将对这两个错误进行...
本文将深入探讨ORA-12737错误的原因、解决方案以及如何利用Oracle最新版本的客户端和工具如Navicat进行问题排查。 ORA-12737错误通常出现在以下场景: 1. 数据库实例未能正常启动或关闭。 2. TNS监听器出现问题,...