步骤
- 创建表空间
create BIGFILE TABLESPACE xxx datafile 'C:\ORACLE\ORADATA\ORCL\xxx.DBF' SIZE 500M AUTOEXTEND ON;
- 新建用户
默认表空间选择刚刚创建的表空间,临时表空间选择temp
- 给新建的用户增加权限
GRANT CONNECT TO newUser;
GRANT RESOURCE TO newUser;
GRANT dba TO newUser;
- 使用命令行开始导入
impdp username/password file=X:\xxx\xxx.dmp ignore=y full=y
如果想在导入的表中的数据增加限制条件使用query=表名:\"where 列名>条件\",表名:\"where 列名>条件\",
如果是linux系统:
query=表名:\"where birthday\>to_timestamp\(\'1995-08-09\',\'yyyy-mm-dd\'\)\",
区别就是在linux中需要在每一个符号前都加转义字符\,而在window中只需要在where语句的前后加\
可能会遇到的问题
- ORA-12560: TNS: 协议适配器错误
检查服务和监听是否开启,若都开启,则在命令行直接输入set ORACLE_SID=a (其中a是自己数据库的sid) - ORA-02380: 概要文件 xxxxx 不存在
产生原因:原数据库的概要文件在新数据库中不存在
解决办法:创建缺失的概要文件
CREATE filename LIMIT
COMPOSITE_LIMIT UNLIMITED
SESSIONS_PER_USER 3
CPU_PER_SESSION UNLIMITED
CPU_PER_CALL UNLIMITED
LOGICAL_READS_PER_SESSION UNLIMITED
LOGICAL_READS_PER_CALL UNLIMITED
IDLE_TIME UNLIMITED
CONNECT_TIME UNLIMITED
PRIVATE_SGA UNLIMITED
FAILED_LOGIN_ATTEMPTS 10
PASSWORD_LIFE_TIME UNLIMITED
PASSWORD_REUSE_TIME UNLIMITED
PASSWORD_REUSE_MAX UNLIMITED
PASSWORD_VERIFY_FUNCTION NULL
PASSWORD_LOCK_TIME 1
PASSWORD_GRACE_TIME 7;
/*
改变新建用户的概要文件
*/
ALTER USER username PROFILE filename;
/*
查看是否修改成功
*/
select username,profile from dba_users where username='username';
- 文件路径找不到
此时应该新建DMP所在目录
create directory Mydir as 'dmp文件路径';
赋予用户读写权限
grant read,write on directory Mydir to username;
此时imp语句应该变为
impdp username/password directory=Mydir dumpfile=xxx.dmp full=y ignore=y
如果出现ORA-65096: 公用用户名或角色名无效问题,使用以下语句
alter session set "_ORACLE_SCRIPT"=true;