Oracle|ORA-00013 导入数据库报错

2022-05-23 12:39:21 浏览数 (1)

问题背景

今天在还原生产环境备份数据到测试环境时,结果导入失败。

提示如下:

问题原因

当时在导出数据库dmp文件时的用户拥有DBA权限,而现在要导入数据库的用户没有DBA权限。

代码语言:javascript复制
--查看用户对象权限
select * from user_tab_privs;

解决方案

方案一:

把导出的用户DBA权限去掉,重新导出(某些情况不适用,不建议)

方案二:

给当前导入的用户新增DBA权限,重新导入。

1. 登陆sqlplus

代码语言:javascript复制
sqlplus / as sysdba

2. 给当前用户赋DBA权限

代码语言:javascript复制
grant dba to utms; --给用户赋dba权限

3. 重新导入成功

4. 导入命令

代码语言:javascript复制
nohup imp 用户名/密码 file=/oradata/tmp/202101-001UTms_back.dmp full=y >/oradata/tmp/imp_dmp_81.log 2>&1 &

5. 查看导入日志

代码语言:javascript复制
tail -f /oradata/tmp/imp_dmp_81.log

福利

有时候可能会遇到数据库版本不同,但是需要相互导入数据的情况.

方案一:

网上有方案说可以直接通过notepad 打开dmp文件直接修改版本号即可,但是在数据库dmp文件特别打的时候,就会特别卡 ---不实用

方案二:

直接通过AlxcTools工具修改dmp文件版本,就可以正常导入了

测试说明:

由Oracle19.06修改为Oracle12.02 亲测可用.

文件下载地址:

链接: https://pan.baidu.com/s/1Na7PsbvZH3A2mHayW06yQQ

密码: bedr

end

0 人点赞