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

 更新时间:2025年11月10日 15:54:21   作者: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,没有开启空表导出,这个解决起来比较麻烦,需要知道哪些表是空表,表与表之间的关联关系

总结

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

相关文章

  • oracle误删数据表还原的二种方法(oracle还原)

    oracle误删数据表还原的二种方法(oracle还原)

    这篇文章主要介绍了oracle误删数据表还原的二种方法,大家参考使用吧
    2014-01-01
  • 全新感受Oracle 9i

    全新感受Oracle 9i

    全新感受Oracle 9i...
    2007-03-03
  • Oracle数据库Schema备份与导入导出的全攻略

    Oracle数据库Schema备份与导入导出的全攻略

    在 Oracle 数据库管理中,Schema(模式)的备份与恢复是保障数据安全的核心操作,本文将系统讲解 Schema 的备份策略、导出方法、导入恢复及常见问题处理,帮助数据库管理员高效完成数据备份与迁移工作,需要的朋友可以参考下
    2025-10-10
  • 新手学oracle常见疑问

    新手学oracle常见疑问

    这篇文章主要介绍了新手学oracle常见的疑问,第一,索引范围扫描,第二,索引唯一扫描,需要的朋友可以参考下
    2015-07-07
  • oracle中的一些常用函数及示例

    oracle中的一些常用函数及示例

    这篇文章主要给大家介绍了关于oracle中的一些常用函数及示例的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-11-11
  • Oracle to_char 日期转换字符串语句分享

    Oracle to_char 日期转换字符串语句分享

    这篇文章主要介绍了Oracle to_char 日期转换字符串语句,别处挖过来的,真是太长了,学习oracle的朋友可以收藏下
    2014-08-08
  • oracle 将多张表中的列合并到一张表中

    oracle 将多张表中的列合并到一张表中

    这篇文章主要介绍了Oracle - 如何将多张表中的列合并到一张表中,需要的朋友可以参考下
    2019-11-11
  • Oracle中返回结果集的存储过程分享

    Oracle中返回结果集的存储过程分享

    Oracle不像SQLServer那样在存储过程中用Select就可以返回结果集,而是通过Out型的参数进行结果集返回的
    2012-07-07
  • Oracle 随机数

    Oracle 随机数

    用于抽样统计,从数据库中按类别随机 抽取各类用户
    2009-05-05
  • 使用Oracle跟踪文件的问题详解

    使用Oracle跟踪文件的问题详解

    从跟踪文件的产生的来源来看,跟踪文件又可以分为两类:一类是数据库的操作人员有意生成的;另一类则是由于出现了异常错误,由数据库自动生成的,本文给大家介绍使用Oracle的跟踪文件的方法,需要的朋友参考下吧
    2021-06-06

最新评论