资源描述:
《dmp文件导入到Oracle数据库.doc》由会员上传分享,免费在线阅读,更多相关内容在工程资料-天天文库。
1、向Oracle数据库导入DMP文件说明:dmp文件为Oracle数据库备份文件。命令:imp:导入emp:导出Oracle数据导入导出imp/exp就相当于oracle数据还原与备份。exp命令可以把数据从远程数据库服务器导出到本地的dmp文件,imp命令可以把dmp文件从本地导入到远处的数据库服务器中。利用这个功能可以构建两个相同的数据库,一个用来测试,一个用来正式使用。执行环境:可以在SQLPLUS.EXE或者DOS(命令行)中执行,DOS中可以执行时由于在oracle8i中安装目录ora81BIN被设置为全局路径,该目录下有EXP
2、.EXE与IMP.EXE文件被用来执行导入导出。oracle用java编写,SQLPLUS.EXE、EXP.EXE、IMP.EXE这两个文件有可能是被包装后的类文件。SQLPLUS.EXE调用EXP.EXE、IMP.EXE所包裹的类,完成导入导出功能。下面介绍的是导入导出的实例。数据导出:1将数据库TEST完全导出,用户名system密码sql导出到D:daochu.dmp中expsystem/sql@TESTfile=d:daochu.dmpfull=y2将数据库中system用户与sys用户的表导出expsystem/sql@TES
3、Tfile=d:daochu.dmpowner=(system,sys)3将数据库中的表table1、table2导出expaichannel/aichannel@TESTDB2file=d:dataewsmgnt.dmptables=(table1、table2)4将数据库中的表table1中的字段filed1以"00"打头的数据导出expsystem/sql@TESTfile=d:daochu.dmptables=(table1)query="wherefiled1like'00%'"上面是常用的导出,对于压缩,既用win
4、zip把dmp文件可以很好的压缩。也可以在上面命令后面加上compress=y来实现。数据的导入:1将D:daochu.dmp中的数据导入TEST数据库中。impsystem/sql@TESTfile=d:daochu.dmpimpaichannel/aichannel@HUSTfull=yfile=file=d:dataewsmgnt.dmpignore=y上面可能有点问题,因为有的表已经存在,然后它就报错,对该表就不进行导入。在后面加上ignore=y就可以了。2将d:daochu.dmp中的表table1导入impsyst
5、em/sql@TESTfile=d:daochu.dmptables=(table1)基本上上面的导入导出够用了。不少情况要先是将表彻底删除,然后导入。!!!若导入时出现有个别表不能成功导入时,只能在数据库里新建表结构,再通过imp命令导入。1.根据导入表时在SQL*PLUS中的提示,会说什么表不能正确创建,在列出相应表的所有表结构。2.在SQL*PLUS里复制表结构到TXT文档,设置好格式,放在C:1.txt下。3.在SQL*PLUS里通过@C:1.txt运行,提示表创建结构成功。4.向新创建的表导入数据。Impsystem/sql
6、@orclfile=d: 955.dmptables=(table1,table2,table3)ignore=y5.观察提示,成败在此一举。注意:操作者要有足够的权限,权限不够它会提示。数据库时可以连上的。可以用tnspingTEST来获得数据库TEST能否连上。附录一:给用户增加导入数据权限的操作第一,启动sql*puls第二,以system/sql登陆第三,createuser用户名IDENTIFIEDBY密码(如果已经创建过用户,这步可以省略)第四,GRANTCREATEUSER,DROPUSER,ALTERUSER,CREATE
7、ANYVIEW,DROPANYVIEW,EXP_FULL_DATABASE,IMP_FULL_DATABASE,DBA,CONNECT,RESOURCE,CREATESESSIONTO用户名字第五,运行-cmd-进入dmp文件所在的目录,impuserid=system/sqlfull=yfile=*.dmp或者impuserid=system/sqlfull=yfile=filename.dmp执行示例:F:WorkOracle_Databackup>impuserid=test/testfull=yfile=inner_notif
8、y.dmp屏幕显示Import:Release8.1.7.0.0-Productionon星期四2月1616:50:052006(c)Copyright2000OracleCor