1 exp/imp作用
用于在数据库之间传递数据。exp从数据库中导出数据到dump文件中,imp从dump文件中把数据导入到数据库.一般我们用来作数据的备份和恢复.
exp导出的是二进制格式的文件,不可以手工编辑,否则会损坏数据。该文件在ORACLE支持的任何平台通用。dump文件在imp时向上兼容.
2. 如何运行
一般exp/imp命令在$ORACLE_HOME/bin目录下
我们可以在sqlplus或命令行下执行,有交互式和非交互式.
注意:要有足够的权限;确保数据库可以连接(可以用tnspng测试)
3. exp
导出工具.将数据库中数据备份压缩成一个二进制系统文件,可以在不同OS间迁移.
三种模式:
A:用户模式:导出用户所有对象以及对象中的数据
B:表模式:导出用户所有表或指定表
C:整个数据库:导出数据库中所有数据对象
exp里加导出的查询条件query= 可以选定导出表的子集
参数:
关键字 说明(默认)
----------------------------------------------
USERID 用户名/口令
FULL 导出整个文件 (N)
BUFFER 数据缓冲区的大小
OWNER 所有者用户名列表
FILE 输出文件 (EXPDAT.DMP)
TABLES 表名列表
COMPRESS 导入一个范围 (Y)
RECORDLENGTH IO 记录的长度
GRANTS 导出权限 (Y)
INCTYPE 增量导出类型
INDEXES 导出索引 (Y)
RECORD 跟踪增量导出 (Y)
ROWS 导出数据行 (Y)
PARFILE 参数文件名
CONSTRAINTS 导出限制 (Y)
CONSISTENT 交叉表一致性
LOG 屏幕输出的日志文件
STATISTICS 分析对象 (ESTIMATE)
DIRECT 直接路径 (N)
TRIGGERS 导出触发器 (Y)
FEEDBACK 显示每 x 行 (0) 的进度
FILESIZE 各转储文件的最大尺寸
QUERY 选定导出表子集的子句
4.imp
导入工具.将exp形成的二进制文件(dump文件)导入到数据库中.
跟exp一样,有三种模式.
只有拥有imp_full_database和DBA权限的用户才能做整个数据库的导入.
导入数据时,ORACLE有一个特定的顺序,可能随数据库版本不同而有所变化.一般是
1. Tablespaces |
2. Profiles |
3. Users |
4. Roles |
5. System Privilege Grants |
6. Role Grants indexes, constraints, audi ting) |
7. Default Roles |
8. Tablespace Quotas |
9. Resource Costs |
10. Rollback Segments |
11. Database Links |
12. Sequences |
13. Snapshots |
14. Snapshot Logs |
15. Job Queues |
16. Refresh Groups |
17. Cluster Definitions |
18. Tables (also grants,comments, |
19. Referential Integrity |
20. POSTTABLES actions |
21. Synonyms |
22. Views |
23. Stored Procedures |
24. Triggers, Defaults and Auditing |
参数:
关键字 说明(默认)
----------------------------------------------
USERID 用户名/口令
FULL 导入整个文件 (N)
BUFFER 数据缓冲区大小
FROMUSER 所有人用户名列表
FILE 输入文件 (EXPDAT.DMP)
TOUSER 用户名列表
SHOW 只列出文件内容 (N)
TABLES 表名列表
IGNORE 忽略创建错误 (N)
RECORDLENGTH IO 记录的长度
GRANTS 导入权限 (Y)
INCTYPE 增量导入类型
INDEXES 导入索引 (Y)
COMMIT 提交数组插入 (N)
ROWS 导入数据行 (Y)
PARFILE 参数文件名
LOG 屏幕输出的日志文件
CONSTRAINTS 导入限制 (Y)
DESTROY 覆盖表空间数据文件 (N)
INDEXFILE 将表/索引信息写入指定的文件
SKIP_UNUSABLE_INDEXES 跳过不可用索引的维护 (N)
ANALYZE 执行转储文件中的 ANALYZE 语句 (Y)
FEEDBACK 显示每 x 行 (0) 的进度
TOID_NOVALIDATE 跳过指定类型 id 的校验
FILESIZE 各转储文件的最大尺寸
RECALCULATE_STATISTICS 重新计算统计值 (N)
5. 可能出现的问题
A:imp和exp版本问题
exp出现ora-00942错误:这是由于装载的表或视图不存在,多半是CATEXP.SQL还没有运行,无法执行Export视图,假如CATEXP.SQL已经运行,则可能是版本错误。
exp出现exp--00003错误:no storage definition found for segment :一般也是执行$ORACLE_HOME/rdbms/admin/catexp.sql可以解决.低版本的exp导出高版本的数据库时也会出现这种错误.(将compress=y加上好像也可以解决)
imp可以成功导入低版本exp生成的文件, 不能导入高版本exp生成的文件.
B:imp和exp使用的字符集不同
如果字符集不同, 导入会失败, 可以改变unix环境变量或者NT注册表里NLS_LANG相关信息,导入完成后再改回来.
C:数据库对象有主外键约束,不符合主外键约束时, 数据会导入失败.可以先导入主表, 再导入依存表,disable目标导入对象的主外键约束, 导入数据后, 再enable.
D:数据库对象已经存在
如果用了参数ignore=y, 会把exp文件内的数据内容导入
如果表有唯一关键字的约束条件, 不合条件将不被导入
如果表没有唯一关键字的约束条件, 将引起记录重复
E:导入到指定用户或表空间时,确定目标用户或表空间已存在,并有足够的空间
F:导入用户自定义的一些类型时可能会失败
G:导入trigger,sequence也可能会出现错误