imp指定导入存储过程

imp指定导入存储过程,第1张

可以通过输入 IMP 命令和各种参数来控制导入 的运行方式。要指定参数, 您可以使用关键字:格式: IMP KEYWORD=value 或 KEY,这个就是imp指定导入存储过程方式

exp help=y

imp help=y

说的很清楚

数据库归档不归档都可以,scott是一个用户名,tiger是这个用户的密码,举两个例子

exp scott/tiger owner=scott file=temp.dmp log=temp.log

exp scott/tiger tables=(emp,dept) file=temp.dmp log=temp.log

 imp导入数据指定表空间,大致有以下几种方法可以:

1. 有一个简单的方法,适用于数据比较少的情况:直接使用UltraEdit打方DMP文件,默认是16进制,切换成文本模式,将里面的:TABLESPACE "TS1"全部替换成TABLESPACE "TS2",然后再导入,不用加什么tablespaces=TS2之类的参数即可,当然加了也无所所谓。

C:\>IMP USER2/USER2 log=C:\plsimp.log file=D:\database\USER1.dmp fromuser=USER1 touser=USER2 ignore=yes tablespaces=TS2

不过有个缺点,如果DMP文件有几百M甚至几G,嘿嘿嘿嘿,不知道UltraEdit有啥反应?

2. 还有另外一种比较好的方法。基本思路都是先从 USER1导出表结构(DMP或者SQL脚本),然后在USER2用户下创建空的数据库表(如果是DMP,则参见方法1;如果是SQL脚本,则稍作修改后以USER2用户执行即可),再将包括数据的DMP导入,注意要设IGNORE=Y,并指定FROMUSER和TOUSER。具体实现方法为:

(1)先用工具导出USER1的表结构(不要导出CHECK和FK,特别是FK!),TOAD和 PL/SQL都有此功能。PL/SQL Developer导出表结构:Tools-->Export User Objects(导出用户对象) -->选择要导出的表(包括Sequence等)-->.sql文件,导出的都为sql文件。或者使用imp的indexfile选项生成表结构的SQL脚本。

(2)在USER2用户下创建相同的表结构

(3)导入完整的数据

PS:

PL/SQL Developer工具 *** 作步骤:

(1)导出表结构:

Tools-->Export User Objects(导出用户对象) -->选择要导出的表(包括Sequence等)-->.sql文件,导出的都为sql文件

(这一步也可以导出一个只包括表结构的DMP文件。)

(2)导出表数据:

Tools-->Export Tables-->选择表,选择SQL Inserts-->.sql文件

(这一步也可以导出一个包括表结构和数据或者只有数据没有表结构图的DMP文件。)

(3)导入表结构:

执行刚刚导出的sql文件,记住要删掉table前的用户名,比如以前这表名为sys.tablename,必须删除sys

(如果是只包括表结构的DMP文件,则使用UltraEdit修改表空间,再导入。如方法1)

(4)导入表数据:

执行刚刚导出的sql文件

(如果是DMP文件,则直接导入即可,注意要设IGNORE=Y,并指定FROMUSER和TOUSER。)

IMP命令 *** 作步骤:

首先:exp user/pw file=file.dmp owner=yourUser1

然后:imp user/pw file=file.dmp indexfile=xxxx.sql fromuser=yourUser1 touser=yourUser2

随后:修改xxxx.sql中的关于有表空间设置的地方为新的表空间,并去掉相关的注释(rem),然后执行xxxx.sql创建相关对象。

最后:imp user/pw file=file.dmp fromuser=yourUser1 touser=yourUser2 ignore=y


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/10004768.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-04
下一篇2023-05-04

发表评论

登录后才能评论

评论列表(0条)

    保存