oracle

关注公众号 jb51net

关闭
首页 > 数据库 > oracle > Oracle11g还原数据库导入dmp文件

Oracle11g还原数据库导入dmp文件的实现方式

作者:Funky_oaNiu

本文详细介绍了如何从dmp文件导入Oracle数据库数据,包括创建用户、授权、导入步骤、处理导入过程中可能出现的错误,以及解决特定问题的方法

1.首先你要知道往哪个用户里面导,先创建个用户然后授权

打开sqlplus,用system登录(或者有dba权限的用户) 一次执行下面的命令语句

CREATE USER "用户名" PROFILE "DEFAULT" IDENTIFIED BY "密码" DEFAULT TABLESPACE "USERS" TEMPORARY TABLESPACE "TEMP" ACCOUNT UNLOCK;
GRANT CREATE ANY TABLE TO "用户名";
GRANT UNLIMITED TABLESPACE TO "用户名";
GRANT "CONNECT" TO "用户名";
GRANT "RESOURCE" TO "用户名";
GRANT CREATE ANY VIEW TO "用户名";
GRANT dba TO "用户名";

2.然后打开cmd,根据自己的数据库执行下面语句

imp 刚才创建的用户名/密码@数据库实例名 full=y file=文件的绝对路径(包含文件名) ignore=y

3.导入过程中报错?怎么重新导入?

如果导入数据有问题的话,大多是表空间缺失,因为dmp文件不会把表空间也备份出来的,若报表空间不存在,删掉用户,建表空间,重新imp就行了

执行下面语句删除用户(慎用,别删错了,这是删除用户和用户底下所有的数据)

drop user 用户名 cascade

4.最后记录一下导入过程中遇到的问题

1.在A用户下导入但是数据却导入到了B用户里

这是由于导入的dmp文件的原因,里面设定了自动导入A用户,这时候你需要重新创建一个Oracle实例,注意不是Oracle用户,是实例,创建过程中一定要设置数据库字符集为ZHS16GBK

如何连接到另外一个Oracle实例?

conn 用户名/密码@实例名

2.导入过程中提示: “XXXX值太大,无法执行”

这就是没有设置ZHS16GBK的原因,打开sqlplus,登录后先确定你连接的数据库是你需要修改的(别改错了),然后登录有dba权限(最高权限)的用户,依次执行以下命令语句

SQL> conn /as sysdba;
SQL> shutdown immediate;//这个可能久一点,不超过5分钟
SQL> startup mount;//归档模式
SQL> alter system enable restricted session;//数据库访问受限状态
SQL> alter system set JOB_QUEUE_PROCESSES=0;
SQL> alter system set AQ_TM_PROCESSES=0;
SQL> alter database open;
SQL> alter database character set internal_use ZHS16GBK;
SQL> alter database character set ZHS16GBK
SQL> shutdown immediate;
SQL> startup;

执行完成之后再次进行导入发现没有问题了

3.导入过程中提示: "表空间不存在"或“表不存在创建触发器失败”

这是因为dmp文件有问题,最初导出dmp文件的时候,没有提前设置好导出空表,只能去原来数据库将缺少的空表或序列手工导进来,可以用Navicat。

4.报错内容包含表缺失

有可能是源头数据库是11g,没有开启空表导出,这个解决起来比较麻烦,需要知道哪些表是空表,表与表之间的关联关系

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文