oracle数据库904_oracle00933怎么解决

oracle数据库904_oracle00933怎么解决今天早上在日志中发现exp备份时出错:..exportingtableBJ_AFFILIATES37rowsexportedEXP-00008:ORACLEerror904encounteredORA-00904::invalididentifier..exportingtable…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

今天早上在日志中发现exp备份时出错:

. . exporting table                  BJ_AFFILIATES         37 rows exported

EXP-00008: ORACLE error 904 encountered

ORA-00904: : invalid identifier

. . exporting table                  BJ_CATEGORIES        175 rows exported

EXP-00008: ORACLE error 1003 encountered

ORA-01003: no statement parsed

. . exporting table                    BJ_LOCATION         12 rows exported

EXP-00008: ORACLE error 904 encountered

ORA-00904: : invalid identifier

. . exporting table                        BJ_TYPE         22 rows exported

EXP-00008: ORACLE error 1003 encountered

ORA-01003: no statement parsed

此错误对前台应用没有任何影响。导出的用户是系统新版本上线时创建的一个新用户,操作过程很简单,从老用户中exp数据,然后imp到新用户,导入导出过程都很正常,没有任何报错,查看错误类型含义:

[oracle@bj47 backup]$ oerr ora 904

00904, 00000, “%s: invalid identifier”

// *Cause:

// *Action:

[oracle@bj47 backup]$ oerr ora 1003

01003, 00000, “no statement parsed”

// *Cause:

// *Action:

看来无法得到原因和采取的活动。网上查询,很多解释都是不同版本的客户端和服务器之间进行exp而导致的,而我的操作是在同一台机器上,显然不是原因。从表DBA_SERVER_ERROR表中查看相应sql,发现如下sql:

SELECT

CNAME, SNAME, SSGFLAG, STSNAME, STSNO, SFILE, SBLOCK,

SDOBJID,             SCHUNKING, SVPOOL, SFLAGS, INAME, ISGFLAG,

ITSNAME, ITSNO, IFILE,             IBLOCK, IDOBJID, IINITRANS,

IMAXTRANS, SPROPERTY, COLTYPE,             COLTYPFLG, BLOCKSIZE,

INTCOLID, OPAQUETYPE      FROM   SYS.EXU9LOBU

WHERE  TOBJID = :1

用sql trace追踪也发现类似的错误,步骤如下:

1、alter system set events=’904 trace name errorstack’;

2、执行exp

3、在udump下的trace文件中发现:

*** SESSION ID:(44.28384) 2008-06-12 11:11:38.105

*** 2008-06-12 11:11:38.105

ksedmp: internal or fatal error

ORA-00904: : invalid identifier

Current SQL statement for this session:

SELECT

BUCKET, ENDPTHASH, ENDPTVAL,             UTL_RAW.CAST_TO_RAW(ENDPTVAL)

ENDPTVAL_RAW      FROM   SYS.EXU8HSTU      WHERE  POBJ

ID = :1 AND             INTCOL = :2      ORDER BY BUCKET

检查对象EXU8HSTU ,发现它的select权限已经赋予了public用户,也就是所有用户应该都可以访问的:

SQL> select * from dba_tab_privs where table_name=’EXU8HSTU’

2  ;

GRANTEE

OWNER                          TABLE_NAME

GRANTOR                        PRIVILEGE

GRANTABLE HIERARCHY

——————————

—————————— ——————————

—————————— —————————————-

——— ———

PUBLIC

SYS                            EXU8HSTU

SYS                            SELECT

NO        NO

那么难道是新用户对UTL_RAW包没有可执行权限?

SQL> select * from dba_tab_privs where table_name=’UTL_RAW’;

果然,记录为空,也就是新用户并没有包UTL_RAW的可执行权限,找到原因就好比了,给新用户赋予包UTL_RAW的可执行权限即可:

grant execute on UTL_RAW to newuser;

SQL> select * from dba_tab_privs where table_name=’UTL_RAW’;

GRANTEE

OWNER                          TABLE_NAME

GRANTOR                        PRIVILEGE

GRANTABLE HIERARCHY

——————————

—————————— ——————————

—————————— —————————————-

——— ———

NEWUSER

SYS                            UTL_RAW

SYS                            EXECUTE

NO        NO

赋予成功后,exp备份也恢复正常。

仔细回想,UTL_RAW的可执行权限为何会被取消?原来是很久以

前404检查的时候要求将所有UTL开头的包的可执行权限从public用户中取消掉,那么老用户备份的时候怎么就没有报错呢?查询以前的备份日志,发现

其实也含有这样的错误,但是只是在某一个表上,因此没有引起注意:

About to export specified tables via Direct Path …

. . exporting table                  BJ_AFFILIATES

37 rows exported

. . exporting table                  BJ_CATEGORIES

175 rows exported

. . exporting table                    BJ_LOCATION

12 rows exported

. . exporting table                        BJ_TYPE

22 rows exported

. . exporting table             NG_ADDISTRIBUTIONS

.

117949 rows exported

. . exporting table            NG_ADMANAGERDB_LOCK

1 rows exported

. . exporting table                         NG_ADS

.

118197 rows exported

. . exporting table                     NG_ADSIZES

144 rows exported

. . exporting table                   NG_ADTARGETS

1 rows exported

. . exporting table                 NG_ADVERTISERS

1775 rows exported

EXP-00008: ORACLE error 904 encountered

ORA-00904: : invalid identifier

. . exporting table             NG_ADVERTISERTYPES

。。。。。。

只有为什么老用户只有一个表报错,而新用户所有表都报错,就不得而知了。。。。。。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/191422.html原文链接:https://javaforall.net

(0)
上一篇 2026年2月1日 下午3:43
下一篇 2026年2月1日 下午4:15


相关推荐

  • eclipse 字体大小设置

    eclipse 字体大小设置窗口 Window 首选项 Preferences 常规 General 外观 Appearence 颜色与字体 ColorsAndFon 在右边的对话框里选择 Java JavaEditorTe 点击出现的修改 Change 按钮 可以设置显示在在主窗体中程序的字体大小 设置完之后点击右下角的应用 Apply 最后点击确定 OK

    2026年3月18日
    1
  • mybatis分页查询之sql server–mysql[通俗易懂]

    mybatis分页查询之sql server–mysql[通俗易懂]freemarker.beansKey”location”wasnotfoundoninstanceoforg.springframework.jdbc.UncategorizedSQLException.freemarker.beansKey”location”wasnotfoundoninstanceofcom.microsoft.sqlserver.jdbc.SQLServerException.sqlserver使用mybatis中分页查询时出现故障

    2022年5月12日
    43
  • LINUX下 Udev详解[通俗易懂]

    如果你使用Linux比较长时间了,那你就知道,在对待设备文件这块,Linux改变了几次策略。在Linux早期,设备文件仅仅是是一些带有适当的属性集的普通文件,它由mknod命令创建,文件存放在/dev目录下。后来,采用了devfs,一个基于内核的动态设备文件系统,他首次出现在2.3.46内核中。Mandrake,Gentoo等Linux分发版本采用了这种方式。devfs创建的设备文件是动态的。但

    2022年4月18日
    47
  • JS动态为对象添加属性

    JS动态为对象添加属性JS 允许在创建完一个对象后 动态给对象添加属性 如下 varobj 动态给对象添加属性的常见方式 obj name aaa obj age 22 console log obj 不常见方式 varkey address varvalue 南京市雨花台区 obj key value console log obj 备注 使用上

    2026年3月17日
    2
  • 再来利用java学学javaweb——–html+css+ JavaScript[通俗易懂]

    再来利用java学学javaweb——–html+css+ JavaScript[通俗易懂]今日内容1.web概念概述2.HTMLweb概念概述*JavaWeb: *使用Java语言开发基于互联网的项目*软件架构: 1.C/S:Client/Server客户端/服务器端 *在用户本地有一个客户端程序,在远程有一个服务器端程序 *如:QQ,迅雷… *优点: 1.用户体验好 *缺点: 1.开发、安装,部署,维护麻烦 2.B/S:Browser/Server浏览器/服务器端 *只需要一个浏览器,用户通过不同的网

    2022年7月12日
    16
  • 免费pac代理地址_pac网址怎么设置

    免费pac代理地址_pac网址怎么设置问题起因:最近上http://nipponcolors.com/没上去,什么DNS污染啥的都试过了,最后是改本地PAC才好使得,大家可以用全局先看一下解决办法:添加如下连两行代码即可…

    2022年10月9日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号