Oracle-21C导入dmp文件

1、前期工作

具体参考该博文

  • Windows操作系统安装Oracle数据库

  • 下载安装Oracle数据库图形管理工具

2、连接和调整数据库环境

2.1、以数据库管理员身份登录数据库

image

++++++++++++++++++++++分割线++++++++++++++++++++++

image

2.2、查询当前会话是否为CDB

image

注意:Oracle 12C以及更高版本中引入了CDB(Container Database)与PDB(Pluggable Database)的新特性;
CDB相当于操作系统,调用并管理各个PDB,PDB相当于真正提供业务需求的数据库实例。

show con_name;

因为Oracle从12c开始引入了容器的概念,所以直接以sysdba用户创建新用户时,会默认在CDB中创建公有用户;

公有用户名需要以“C##”或“c##”开头,违反该规则时,会遇到下面的报错信息:

ORA-65096: 公用用户名或角色名无效
65096. 00000 -  "invalid common user or role name"
*Cause:    An attempt was made to create a common user or role with a name
           that was not valid for common users or roles. In addition to the
           usual rules for user and role names, common user and role names
           must consist only of ASCII characters, and must contain the prefix
           specified in common_user_prefix parameter.
*Action:   Specify a valid common user or role name

2.3、使用PDB

如果用户名开头不想使用“C##”或“c##”,则需要做如下操作:

2.3.1、查询PDB列表

image

show pdbs;

2.3.2、开启PDB

image

alter pluggable database pdb名称 open;

2.3.3、修改会话的容器

image

alter session set container=pdb名称;

3、创建新数据库用户

3.1、在其他用户目录中选择创建用户

image

3.2、为新用户设置名称和密码

image

注意:用户名为大写字母;如果为小写字母,则在登录和修改密码等操作时,会提示该用户不存在(ORA-01017)

3.3、为新用户授予角色

image

全部设置为管理员

++++++++++++++++++++++分割线++++++++++++++++++++++

image

全部采用默认值

3.4、为新用户授予系统权限

image

可以全部设置为管理员,但SYSRAC除外,否则会报错。

3.5、新用户登录

image

注意:服务名要填该用户的容器

4、导入dmp文件

注意:导入dmp文件前,需要先从源数据库导出dmp文件:

exp 账号/密码@数据库IP地址/服务名 file=导出文件的路径/导出文件的名称.dmp log=导出日志的路径/导出日志的名称.log owner=(账号)

4.1、imp导入命令

image

格式说明: imp 用户名/密码@IP:端口/服务名 file=dmp文件路径 full=y

imp HTEST/HTEST@1ocalhost/XEPDB1 file=C:\kkk\数据库备份文件名.dmp fu11=y

注意:导入时可能遇到“ORA-00959”错误,说明缺少对应的表空间;此时需要创建表空间,再重新创建用户导入即可:
create tablespace 表空间名称
datafile '表空间路径\表空间文件名称.dbf'
size 1000M
autoextend on
next 10M
maxsize unlimited;

4.2、IMP-00037错误

执行imp命令导入dmp文件时,可能会出现IMP-00037错误,错误原因主要有以下两种:

  • 数据库字符集不一致

  • dmp文件在传输过程中损坏

4.2.1、查询数据库字符集

select * from nls_database_parameters where parameter='NLS_CHARACTERSET';

4.2.2、校验dmp文件md5

certutil -hashfile dmp文件路径 MD5

4.3、ORA-12899错误

这个错误是因为Oracle字符集不同,汉字占的长度不同造成的。

中文在ZHS16GBK中占2个字节,在UTF-8中却占3个字节,所以汉字导入UTF-8字符集的数据库就很容易出现字段长度不够。

解决办法有两种:

  • 增加字段长度(推荐)

  • 修改字符集

5、相关拓展

Oracle数据库字符集概述及修改方式

本文参考

【1】【百战黄沙始读书】【ORACLE导入遇到ORACLE错误959解决方法】【博客园】【2017-12-25】

posted @ 2023-07-25 17:56  Javaer1995  阅读(429)  评论(0编辑  收藏  举报