Oracle导出导出有两中方式:第一段:利用exp imp导出导入;第二段:利用Oracel数据泵expdp impdp导出导入.
第一段:利用exp imp导出导入
exp imp 语法如下:
exp:
①.) 将数据库orcl完全导出
imp:
①.) 将备份文件bak.dmp导出数据库
如果数据表中表已经存在,会提示错误,在后面加上ignore=y就可以了.
解决办法:
①.、设置deferred_segment_creation参数为false后,无论是空表,还是非空表,都分配segment.
在sqlplus中,执行如下命令:
SQLalter system set deferred_segment_creation=false;
查看:
SQLshow parameter deferred_segment_creation;
该值设置后,只对后面新增的表起作用,对之前建立的空表不起作用,并且注意要重启数据库让参数生效.
使用 ALLOCATE EXTEN可以为数据库对象分配Extent,语法如下:
alter table table_name allocate extent
构建对空表分配空间的SQL命令:
SQLselect 'alter table '||table_name||' allocate extent;' from user_tables where num_rows=0
批量生成要修改的语句.
然后执行这些修改语句,对所有空表分配空间.
此时用exp命令,可将包括空表在内的所有表导出.
第二段:利用expdp impdp导出导入
在Oracle10g中exp imp被重新设计为Oracle Data Pump(保留了原有的 exp imp工具)
数据泵与传统导出导入的区别;
expdp导出数据:
①.、为输出路径建立一个数据库的directory对象.
create or replace directory dumpdir as 'd:\';
可以通过:select * from dba_directories;查看.
grant read,write on directory dumpdir to test_expdp;
expdp test_expdp/test_expdp directory=dumpdir dumpfile=test_expdp_bak.dmp logfile=test_expdp_bak.log schemas=test_expdp
注意:这句话在cmd窗口中运行,并且最后不要加分号,否则会提示错误.因为这句话是操作系统命令而不是SQL.
impdp导入数据:
①.、给将要进行数据导入的用户授权访问.
grant read,write on directory dumpdir to test_impdp;
impdp test_impdp/impdp directory=dumpdir dumpfile=test_expdp_bak.dmp remap_schema=test_expdp:test_impdp
数据导出具体如下:
将数据库TEST完全导出,用户名system 密码manager 导出到D:\daochu.dmp中.
将数据库中system用户与sys用户的表导出.
将数据库中的表table1中的字段filed1以"00"打头的数据导出.
将D:\daochu.dmp 中的数据导入 TEST数据库中.
将d:\daochu.dmp中的表table1 导入.
第一段:使用PLSQL导出导入ORACLE数据库:
①.、打开plsql--工具---->>导出用户对象(可以导出表结构和序列、视图)
ps:如果上面不选中"包括所有者",这样到导出的表结构等就不包含所有者,
这样就可以将A所有者的表结构等导入到B所有者的表空间中
①.、想要导入数据库必须首先创建用户和表空间并赋权限
(1)创建用户:
(1)导入表结构和序列: plsql--->>工具--->>导入表
到此数据导入完成;
注:(1)创建的用户和表空间是和导出数据库中的用户和表空间对应的;如要从A数据库中导出B用户C表空间下的所有表、数据、序列到M数据库;则在M数据库中创建B用户
和C表 空间.
数据导出:
①.将数据库TEST完全导出,用户名system密码manager导出到D:\daochu.dmp中
①.、首先通过tode创建或者克隆新的数据库用户,如下图所示.
以上就是土嘎嘎小编为大家整理的oracle如何导出方案相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!