IMP工具是Oracle公司官方提供的一款数据库工具,其能够根据预定的格式快速地实现数据库表的导入操作,给数据库管理员带来了极大的便利。在实际应用中,IMP工具可以支持多种格式的数据文件,包括CSV、TXT、XML、Excel等格式的文件,不仅可以实现批量导入、更新、插入等操作,而且还可以直接将数据文件导入数据库表中,并且支持数据转换、部分字段导入、复杂数据结构处理等高级功能。下文将从原理、使用方法、优点和缺点等方面进行探讨和分析。
成都网站建设哪家好,找创新互联建站!专注于网页设计、网站建设公司、微信开发、成都小程序开发、集团企业网站建设等服务项目。核心团队均拥有互联网行业多年经验,服务众多知名企业客户;涵盖的客户类型包括:咖啡厅设计等众多领域,积累了大量丰富的经验,同时也获得了客户的一致称赞!
一、IMP工具的原理
IMP(Import)工具是Oracle公司的数据库工具之一,与EXP(Export)相对应。Import工具可以将数据从不同数据源导入Oracle的数据库中。相比于手动插入数据的方式,IMP工具可以极大地提高数据导入的效率,降低出错的概率。
IMP工具的工作流程大致如下:
1. 读取导入参数:IMP会读取用户在命令行上输入的参数,如文件路径、表名、数据格式等。
2. 连接数据库:IMP需要连接用户指定的数据库,以便可以将数据准确地导入到指定的表中。用户需要输入数据库IP、端口、用户名、密码等信息,而后进行连接。
3. 创建表结构:如果用户指定的表不存在,IMP会根据导入的数据创建一个新的表。
4. 执行导入操作:IMP开始执行导入操作,将源数据的值映射到目标表的字段中。
5. 完成导入:完成导入操作后,IMP会销毁与数据库的连接,并输出导入结果,告知用户是否出现错误。
二、IMP工具的使用方法
(一)准备工作
在使用IMP工具进行数据库导入操作前,需要进行一些准备工作,包括创建表、准备导入数据文件等。
(二)命令行输入
IMP工具可以通过命令行的方式进行调用,在命令行中输入以下命令即可:
imp user/pwd@dbname file=filename.log fromuser=user_touser=table constrnts=y
其中,“user/pwd”表示用户名和密码,”dbname”表示需要导入的数据库名称,“filename.log”为数据文件名称,”user_to_user”和”table”表示要导入的表名。
(三)导入操作
在输入完命令后,IMP会根据用户指定的参数进行导入操作,如果操作成功,则会在终端上输出成功信息,否则会输出错误信息。
三、IMP工具的优点和缺点
(一)优点
1. 易于使用:IMP工具的操作简单明了,可以使用命令行或GUI界面进行调用,无需编写繁杂的SQL语句。
2. 自动化处理:IMP工具可以自动将导入的文件映射到数据库表中,大幅减少了手动处理的时间和麻烦。
3. 支持多种数据格式:IMP工具可以支持多种数据格式,如TXT、CSV、XML等,而不仅仅局限于Oracle数据库文件的格式,方便用户进行数据导入操作。
4. 支持大规模数据导入:IMP工具可以支持大规模的数据导入操作,同样减少了将数据插入数据库的时间和人力成本。
(二)缺点
1. 对数据完整性有影响:IMP工具在导入数据的时候,不会对原始数据进行过滤,可能会存在数据不一致,导致数据的完整性受到影响的问题。
2. 数据类型限制:IMP工具的导入功能虽然支持多种数据类型,但仍有一些数据格式并不支持,也存在导入中数据类型转换错误的风险。
3. 处理复杂数据结构问题:IMP工具在处理复杂的数据结构时,可能会存在一定的问题,配置文件的设置需要谨慎。
综上所述,IMP工具作为一款能够实现数据库表的快速导入操作的工具,其具有非常广阔的应用前景,帮助数据库管理员大幅提高工作效率。IMP工具不仅操作简单,同时也支持多种格式数据的导入与转换,具有应用范围广、效率高的特点,在实际应用中受到越来越多的青睐。但其也存在一些缺陷,使用者需要在使用中进行注意,谨慎处置,才能更大限度地发挥其导入功能的优势。
相关问题拓展阅读:
写法跟expdp命令一样 如导出命令: expdp 用户名/密码 schemas=用户名 directory=exp dumpfile=*.dmp logfile=exp.log
导入命令只需把expdp换成impdp就行 impdp 用户名/密码 schemas=用户名 directory=exp dumpfile=*.dmp logfile=imp.log
注意事项:
首先从兆洞导出的机器中传到要导入数据库的机器上,如Windows可以放在D:\imp 文件夹下唤念(如果两台机器操作系统不同,需使用二进制传输dmp文件)
在要导入数据的数据库创建导和猜困入导出目录
SQL>create directory as ‘D:\imp’;
3.命令行中开始导入 impdp 用户名/密码 schemas=用户名 directory=exp dumpfile=*.dmp logfile=exp.log
先把文件copy到另外一台电脑。Impdp和imp不一样,文件必须在本机。
1、逗咐按表导入 p_street_area.dmp文件中的表山正纯,此文件是以gwm用户按schemas=gwm导出的: impdp gwm/gwm@fgisdb dumpfile =p_street_area.dmp logfile=imp_p_street_area.log directory=dir_dp tables=p_street_area job_name=my_job2、按用户导入(可以将用户信息直接导入,即如果用户信息不清搭存在的情况下也可以直接导入) impdp gwm/gwm@fgisdb schemas=gwm dumpfile =expdp_test.dmp logfile=expdp_test.log directory=dir_dp job_name=my_job
其实这些网上有很多,你搜下就有了,我这里有存档的,你参照下:
exp 命令的参数:
将数据库内的各对象以二进制方式下载成dmp文件,方便数据迁移。
buffer:下载数据缓冲区,以字节为单位,缺省依赖操作系统
consistent:下载期间所涉及的数据保持read only,缺省为n
direct:使用直通方式 ,缺省为n
feeback:显示处理记录条数,缺省为0,即不显示
file:输出文件,缺省为expdat.dmp
filesize:输出文件大小,缺省为操作系统更大值
indexes:是否下载索引,缺省为n,这是指索引的定义而非数据,exp不下载索引数据
log:log文件,缺省为无迟陪,在标准输出显示
owner:指明下载的用户名
query:选择记录的一个子集
rows:是否下载表记录
tables:输出的表名列表
导出整个实例
exp dbuser/oracle file=oradb.dmp log=oradb.log full=y consistent=y direct=y
user应具有dba权限
导出某个用户所有对象
exp dbuser/oracle file=dbuser.dmp log=dbuser.log owner=dbuser buffer=feedback=10000
导出一张或几张码闷蠢表
exp dbuser/oracle file=dbuser.dmp log=dbuser.log tables=table1,table2 buffer=feedback=10000
导出某张表的部分数据
exp dbuser/oracle file=dbuser.dmp log=dbuser.log tables=table1 buffer=feedback=10000 query=\”where col1=\’…\’ and col2 \ create directory dump_test as ‘/home/oracle/oracle10g’;
Directory created.
SQL> drop directory dump_test;
Directory dropped.
SQL> create directory dump_test as ‘/u01/oracledmp’;
Directory created.
–接下来记得创建directory在系统上,并赋好权限
$ expdp anlen/anlen123 directory=dumpdir dumpfile=anlen.dmp
Export: Release 10.2.0.4.0 – Production on Saturday, 12 June,:43:20
Copyright (c) 2023, 2023, Oracle. All rights reserved.
Connected to: Oracle Database 10g Enterprise Edition Release 10.2.0.4.0 – Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options
Starting “ANLEN”.”SYS_EXPORT_SCHEMA_01″: anlen/******** directory=dumpdir dumpfile=anlen.dmp
Estimate in progress using BLOCKS method…
Processing object type SCHEMA_EXPORT/TABLE/TABLE_DATA
Total estimation using BLOCKS method: 1.125 MB
Processing object type SCHEMA_EXPORT/USER
Processing object type SCHEMA_EXPORT/SYSTEM_GRANT
Processing object type SCHEMA_EXPORT/ROLE_GRANT
Processing object type SCHEMA_EXPORT/DEFAULT_ROLE
Processing object type SCHEMA_EXPORT/PRE_SCHEMA/PROCACT_SCHEMA
Processing object type SCHEMA_EXPORT/SEQUENCE/SEQUENCE
Processing object type SCHEMA_EXPORT/TABLE/TABLE
Processing object type SCHEMA_EXPORT/TABLE/INDEX/INDEX
Processing object type SCHEMA_EXPORT/TABLE/CONSTRAINT/CONSTRAINT
Processing object type SCHEMA_EXPORT/TABLE/INDEX/STATISTICS/INDEX_STATISTICS
Processing object type SCHEMA_EXPORT/TABLE/COMMENT
. . exported “ANLEN”.”DBA_01″571.2 KBrows
. . exported “ANLEN”.”DBA_02″278.4 KBrows
Master table “ANLEN”.”SYS_EXPORT_SCHEMA_01″ successfully loaded/unloaded
******************************************************************************
Dump file set for ANLEN.SYS_EXPORT_SCHEMA_01 is:
/u01/dmpdir/anlen.dmp
Job “ANLEN”.”SYS_EXPORT_SCHEMA_01″ successfully completed at 14:43:41
这个百度上一搜一大把,都说的很详细,楼主没搜过,
数据导出:
1 将数据库TEST完全导出,用户名system 密码manager 导出到D:daochu.dmp中
exp system/manager@TEST file=d:daochu.dmp full=y
2 将数据库中system用户与sys用户的表导出
exp system/manager@TEST file=d:daochu.dmp owner=(system,sys)
3 将数据库中的表inner_notify、notify_staff_relat导出
exp aichannel/aichannel@TESTDB2 file= d:datanewgnt.dmp tables=(inner_notify,notify_staff_relat)
4 将数据库中的表table1中的字段filed1以”00″打头的数据导出
exp system/manager@TEST file=d:daochu.dmp tables=(table1) query=” where filed1 like ‘00%'”
上面是常用的导出,对于压缩,既用winzip把dmp文件可以很好的压缩。
也可以在上面命令后面 加上 compress=y 来实现。
数据的导入
1 将D:daochu.dmp 中的数据导入咐族 TEST数据库中。
imp system/manager@TEST file=d:daochu.dmp
imp aichannel/aichannel@HUST full=y file=d:datanewgnt.dmp ignore=y
上面可能有点问题,因为有的表已经存在,然后它就报错,对该表就不进行导入。
在后面加上 ignore=y 就可以了。
2 将d:daochu.dmp中的表table1 导入
imp system/manager@TEST file=d:daochu.dmp tables=(table1)
基本上上面的导入导出够用了。不少情况要先是将表彻底删除,然后导入。
注意:
操作者要有足够的权限,权限不够它会提示。
数据库时可以连上的。可以用tnsping TEST 来获得数据库TEST能否连上。
当然,上面的方法在导出数据时可能会导出很大的包,那是因为你的用户可能在授权的时候授予了DBA的权限,所以可以采用下面方法来进行数据库备份:
数据库备份
建议系统过渡后,每周进行一次备份。或者在数据表发生重大改变前,对要改世伏变的数据表进行备份。
执行以下步骤,进行备份。
在搜简携命令行里,敲入“cmd”,回车,进入命令行窗口。
在窗口中,输入:
exp mas/123456@mas
系统提示:输入数组提取缓冲区大小: 4096 >
可以直接回车;
系统提示:导出文件: EXPDAT.DMP>
此处输入导出文件的位置,其路径必须存在,Oracle在这里不会自动建立路径,但可以建立文件名。备份文件以dmp作为后缀。
输入内容如:e:\work\mas_db_090925v1.dmp 回车
系统提示: (1)E(完整的数据库),(2)U(用户) 或 (3)T(表): (2)U > u
此处可以输入u,也可以直接回车,因为系统此时默认的是U
系统提示:导出权限(yes/no):yes>回车
系统提示:导出表数据(yes/no):yes>回车
系统提示:压缩区(yes/no):yes>回车
系统提示:要导出的用户: (RETURN 以退出) > mas
系统提示:要导出的用户: (RETURN 以退出) > 回车
此时系统会自动进行备份
本文对Oracle数据的导入导出 imp ,exp 两个命令进行了介绍, 并对其相应的参数进行了说明,然后通过一些示例进行演练,加深理解.
文章最后对运用这两个命令可能出现的问题(如权限不够,不同oracle版本)进行了探讨,并提出了相应的解决方案;
本文部分内容摘录自网络,感谢网友的经验总结;
一.说明
oracle 的exp/imp命令用于实现对数据库的导出/导入操作;
exp命令用于把数据从远程数据库服务器导出至本地,生成dmp文件;
imp命令用于把本地的数据库dmp文件从本地导入到远程的Oracle数据库中。
二.语法
可以通过在命令行输入 imp help=y 获取imp的语法信息:
=============================================================================
C:\Documents and Settings\auduser>imp help=y
Import: Release 9.0.1.1.1 – Production on 星期二 5月 20 18:21:
(c) Copyright 2023 Oracle Corporation. All rights reserved.
可以通过输入 IMP 命令和您的用户名/口令
后接用户名/口令的命令:
例程: IMP SCOTT/TIGER
或者, 可以通过输入 IMP 命令和各种参数来控制“导入”
按照不同参数。要指定参数,您可以使用关键字:
格式: IMP KEYWORD=value 或 KEYWORD=(value1,value2,…,vlaueN)
例程: IMP SCOTT/TIGER IGNORE=Y TABLES=(EMP,DEPT) FULL=N
或 TABLES=(T1: P1,T1: P2),如果 T1 是分区表
USERID 必须是命令行中的之一个参数。
关键字 说明(默认)关键字 说明(默认)
——
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)
FEEDBACK 每 x 行显示进度 (0)
TOID_NOVALIDATE跳过指定类型 ID 的验证
FILESIZE 每个转储文件的更大大小
STATISTICS始终导入预计算的统计信息
RESUMABLE遇到与空格有关的错误时挂起 (N)
RESUMABLE_NAME用来标识可恢复语句的文本字符串
RESUMABLE_TIMEOUT RESUMABLE 的等待时间
COMPILE 编译过程, 程序包和函数 (Y)
下列关键字仅用于可传输的表空间
TRANSPORT_TABLESPACE 导入可传输的表空间元数据 (N)
TABLESPACES 将要传输到数据库的表空间
DATAFILES 将要传输到数据库的数据文件
TTS_OWNERS 拥有可传输表空间集中数据的用户
==============================================
同样可以通过输入 exp help=y 获取exp的语法信息
Microsoft Windows XP
(C) 版权所有Microsoft Corp.
C:\Documents and Settings\auduser>exp help=y
Export: Release 9.0.1.1.1 – Production on 星期二 5月 20 18:26:
(c) Copyright 2023 Oracle Corporation. All rights reserved.
通过输入 EXP 命令和用户名/口令,您可以
后接用户名/口令的命令:
例程: EXP SCOTT/TIGER
或者,您也可以通过输入跟有各种参数的 EXP 命令来控制“导出”
按照不同参数。要指定参数,您可以使用关键字:
格式: EXP KEYWORD=value 或 KEYWORD=(value1,value2,…,valueN)
例程: EXP SCOTT/TIGER GRANTS=Y TABLES=(EMP,DEPT,MGR)
或 TABLES=(T1: P1,T1: P2),如果 T1 是分区表
USERID 必须是命令行中的之一个参数。
关键字 说明(默认)关键字 说明(默认)
——
USERID 用户名/口令FULL导出整个文件 (N)
BUFFER 数据缓冲区大小OWNER 所有者用户名列表
FILE输出文件 (EXPDAT.DMP) TABLES表名称列表
COMPRESS 导入到一个区 (Y) RECORDLENGTH IO 记录的长度
GRANTS 导出权限 (Y)INCTYPE 增量导出类型
INDEXES 导出索引 (Y)RECORD跟踪增量导出 (Y)
DIRECT 直接路径 (N)TRIGGERS 导出触发器 (Y)
LOG屏幕输出的日志文件 STATISTICS 分析对象 (ESTIMATE)
ROWS 导出数据行 (Y)PARFILE 参数文件名
CONSISTENT 交叉表一致性 CONSTRAINTS 导出约束条件 (Y)
FEEDBACK每 x 行显示进度 (0)
FILESIZE每个转储文件的更大大小
FLASHBACK_SCN用于回调会话快照的 SCN
FLASHBACK_TIME用来获得最接近于指定时间的 SCN 的时间
QUERY 用来导出表的子集的选择子句
RESUMABLE遇到与空格有关的错误时挂起 (N)
RESUMABLE_NAME用来标识可恢复语句的文本字符串
RESUMABLE_TIMEOUT RESUMABLE 的等待时间
TTS_FULL_CHECK对 TTS 执行完全或部分相关性检查
TABLESPACES要导出的表空间列表
TRANSPORT_TABLESPACE 导出可传输的表空间元数据 (N)
TEMPLATE 调用 iAS 模式导出的模板名称
三.使用示例
3.1 数据导出:
1 将数据库SampleDB完全导出,用户名system 密码manager 导出到E:\SampleDB.dmp中
exp system/manager@TestDB file=E:\sampleDB.dmp full=y
2 将数据库中system用户与sys用户的表导出
exp system/manager@TestDB file=E:\sampleDB.dmp owner=(system,sys)
3 将数据库中的表 TableA,TableB 导出
exp system/manager@TestDB file=E:\sampleDB.dmp tables=(TableA,TableB)
4 将数据库中的表tableA中的字段filed1 值为 “王五” 的数据导出
exp system/manager@TestDB file=E:\sampleDB.dmp tables=(tableA) query=’ where filed1=’王五’
如果想对dmp文件进行压缩,可以在上面命令后面 加上 compress=y 来实现。
3.2 数据的导入
1 将备份数据库文件中的数据导入指定的数据库SampleDB 中,如果 SampleDB 已存在该表,则不再导入;
imp system/manager@TEST file=E:\sampleDB.dmp full=y ignore=y
2 将d:\daochu.dmp中的表table1 导入
imp system/manager@TEST file=E:\sampleDB.dmp tables=(table1)
3. 导入一个完整数据库
imp system/manager file=bible_db log=dible_db full=y ignore=y
4. 导入一个或一组指定用户所属的全部表、索引和其他对象
imp system/manager file=seapark log=seapark fromuser=seapark imp
system/manager file=seapark log=seapark fromuser=(seapark,amy,amyc,harold)
5. 将一个用户所属的数据导入另一个用户
imp system/manager file=tank log=tank fromuser=seapark touser=seapark_copy
imp system/manager file=tank log=tank fromuser=(seapark,amy)
touser=(seapark1, amy1)
6. 导入一个表
imp system/manager file=tank log=tank fromuser=seapark TABLES=(a,b)
7. 从多个文件导入
imp system/manager file=(paycheck_1,paycheck_2,paycheck_3,paycheck_4)
log=paycheck, filesize=1G full=y
8. 使用参数文件
imp system/manager parfile=bible_tables.par
bible_tables.par参数文件:
#Import the sample tables used for the Oracle8i Database Administrator’s
Bible. fromuser=seapark touser=seapark_copy file=seapark log=seapark_import
参数文件示例见附录
9. 增量导入
imp system./manager inctype= RECTORE FULL=Y FILE=A
不少情况下要先将表彻底删除,然后导入。
四.参数说明
4.1、8i EXP常用选项
1、FULL,这个用于导出整个数据库,在ROWS=N一起使用时,可以导出整个数据库的结构。例如:
exp sys file=./db_str.dmp log=./db_str.log full=y rows=n compress=y direct=y
2、BUFFER和FEEDBACK,在导出比较多的数据时,我会考虑设置这两个参数。例如:
exp new file=yw97_2023.dmp log=yw97_2023_3.log feedback=10000 buffer=tables=WO4,OK_YT
3、FILL和LOG,这两个参数分别指定备份的DMP名称和LOG名称,包括文件名和目录,例子见上面。
需要说明的是,EXP可以直接备份到磁带中,即使用FILE=/dev/rmt0(磁带设备名),但是一般我们都不这么做,原因有二:一、这样做的速度会慢很多,二、现在一般都是使用磁带库的,不建议直接对磁带进行操作。至于没有使用磁带库的朋友可以考虑和UNIX的TAR结合使用。
如果你真想使用EXP直接到磁带,你可以参考Metalink文章“EXPORTING TO TAPE ON UNIX SYSTEMS”(文档号:30428.1),该文中有详细解释。
4、COMPRESS参数将在导出的同时合并碎块,尽量把数据压缩到initial的EXTENT里,默认是N,一般建议使用。DIRECT参数将告诉EXP直接读取数据,而不像传统的EXP那样,使用SELECT来读取表中的数据,这样就减少了SQL语句处理过程。一般也建议使用。不过有些情况下DIRECT参数是无法使用的。
5、如何使用SYSDBA执行EXP/IMP?
这是一个很现实的问题,有时候我们需要使用SYSDBA来执行EXP/IMP,如进行传输表空间的EXP/IMP,以及在9i下用SYS用户来执行EXP/IMP时,都需要使用SYSDBA才可。我们可以使用下面方式连入EXP/IMP:
exp “‘sys/sys as sysdba'” file=1.dmp tables=gototop.t rows=n
6、QUERY参数后面跟的是where条件,值得注意的是,整个where子句需要使用””括起来,where子句的写法和SELECT中相同,如果是UNIX平台所有”和’都需要使用\u26469屏蔽它们的特殊含义:
exp gototop/gototop file=1.dmp log=1.log tables=cyx.t query=”where c1=20 and c2=gototop”
如果是windows平台,则使用下面的格式:
exp c/c@ncn file=c.dmp log=c.log tables=t query=”””where id=1 and name=’gototop'”””
4.2、8i IMP常用选项
1、FROMUSER和TOUSER,使用它们实现将数据从一个SCHEMA中导入到另外一个SCHEMA中。
2、IGNORE、GRANTS和INDEXES,其中IGNORE参数将忽略表的存在,继续导入,这个对于需要调整表的存储参数时很有用,我们可以先根据实际情况用合理的存储参数建好表,然后直接导入数据。而GRANTS和INDEXES则表示是否导入授权和索引,如果想使用新的存储参数重建索引,或者为了加快到入速度,我们可以考虑将INDEXES设为N,而GRANTS一般都是Y。
另外一个EXP/IMP都有的参数是PARFILE,它是用来定义EXP/IMP的参数文件,也就是说,上面的参数都可以写在一个参数文件中,但我们一般很少使用。
4.4、Oracle9i EXP功能描述
Oracle9i EXP在原有的基础上新增了部分新的参数,按功能主要分为以下几个部分:
1、OBJECT_CONSISTENT – 用于设置EXP对象为只读以保持对象的一致性。默认是N。
2、FLASHBACK_SCN和FLASHBACK_TIME – 用于支持FLASHBACK功能而新增。
3、RESUMABLE、RESUMABLE_NAME和RESUMABLE_TIMEOUT – 用于支持RESUMABLE空间分配而新增。
4、TTS_FULL_CHECK – 用于在传输表空间时使用依赖性检查。
5、TEMPLATE – 用于支持iAS。
6、TABLESPACES – 设置表空间导出模式。个人觉得对于一般用户而言,这个才是新增参数中最实用的一个,可以让用户在原来的FULL、OWNER、TABLES的基础上多了一种选择,使得EXP更加灵活。
五、不同版本的EXP/IMP问题?
一般来说,从低版本导入到高版本问题不大,麻烦的是将高版本的数据导入到低版本中,在Oracle9i之前,不同版本Oracle之间的EXP/IMP可以通过下面的方法来解决:
1、在高版本数据库上运行底版本的catexp.sql;
2、使用低版本的EXP来导出高版本的数据;
3、使用低版本的IMP将数据库导入到底版本数据库中;
4、在高版本数据库上重新运行高版本的catexp.sql脚本。
但在9i中,上面的方法并不能解决问题。如果直接使用底版本EXP/IMP会出现如下错误:
EXP-00008: ORACLE error %lu encountered
ORA-00904: invalid column name
这已经是一个公布的BUG,需要等到Oracle10.0才能解决,BUG号为2261,你可以到METALINK上去查看有关此BUG的详细信息。
BUG归BUG,我们的工作还是要做,在没有Oracle的支持之前,我们就自己解决。在Oracle9i中执行下面的SQL重建exu81rls视图即可。
CREATE OR REPLACE view exu81rls
(objown,objnam,policy,polown,polsch,polfun,stmts,chkopt,enabled,spolicy)
AS select u.name, o.name, r.pname, r.pfschma, r.ppname, r.pfname,
decode(bitand(r.stmt_type,1), 0,”, ‘SELECT,’)
|| decode(bitand(r.stmt_type,2), 0,”, ‘INSERT,’)
|| decode(bitand(r.stmt_type,4), 0,”, ‘UPDATE,’)
|| decode(bitand(r.stmt_type,8), 0,”, ‘DELETE,’),
r.check_opt, r.enable_flag,
DECODE(BITAND(r.stmt_type, 16), 0, 0, 1)
from user$ u, obj$ o, rls$ r
where u.user# = o.owner#
and r.obj# = o.obj#
and (uid = 0 or
uid = o.owner# or
exists ( select * from session_roles where role=’SELECT_CATALOG_ROLE’)
)
/
grant select on sys.exu81rls to public;
/
六、其他问题
本文只讨论了Oracle8i和9i中的EXP/IMP的一些情况,对于之前的版本,在8.0.X中,除了QUERY参数不能用外,其它差别不大。针对没有QUERY的情况,我们可以先在数据库中使用查询条件建立临时中间表,然后使用EXP导出这个中间表即可。至于Oracle7因为目前使用的人较少,gototop不打算在此做详细解释了,如果读者朋友有需求,你可以参考Metalink文档:“Overview of Export and Import in Oracle7”(文档号:61949.1)。关于EXP/IMP的详细参数信息你可以通过EXP/IMP HELP=Y来获得。
另外关于传输表空间的更多信息可以参考下面的Metelink文档,本文不再详述。
Transportable Tablespaces — An Example to setup and use.
Perform tablespace point-in-time recovery using Transportable Tablespace.
在进行并行EXP/IMP的时候,如果IMP过程建索引的话不建议同时运行5个以上的IMP,如果你想加快速度,可以在IMP的时候不建索引,这样只要内存允许,可以多跑几个,然后是SQL脚本创建需要的索引。
注意:
操作者要有足够的权限,权限不够它会提示。
数据库是否可以连上, 可以用tnsping TestDB 来获得数据库 TestDB 能否连上。
附录一:
给用户增加导入数据权限的操作
之一, 启动sql*puls
第二,以system/manager登陆
第三,create user 用户名 IDENTIFIED BY 密码(如果已经创建过用户,这步可以省略)
第四,GRANT CREATE USER,DROP USER,ALTER USER ,CREATE ANY VIEW ,
DROP ANY VIEW,EXP_FULL_DATABASE,IMP_FULL_DATABASE,
DBA,CONNECT,RESOURCE,CREATE SESSION TO 用户名字
第五, 运行-cmd-进入dmp文件所在的目录,
imp userid=system/manager full=y file=*.dmp
或者 imp userid=system/manager full=y file=filename.dmp
附录二:
Oracle 不允许直接改变表的拥有者, 利用Export/Import可以达到这一目的.
先建立import9.par,
然后,使用时命令如下:imp parfile=/filepath/import9.par
例 import9.par 内容如下:
FROMUSER=TGPMS
TOUSER=TGPMS2 (注:把表的拥有者由FROMUSER改为TOUSER,FROMUSER和TOUSER的用户可以不同)
ROWS=Y
INDEXES=Y
GRANTS=Y
CONSTRAINTS=Y
BUFFER=409600
file==/backup/ctgpc_.dmp
imp指定表导入数据库的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于imp指定表导入数据库,imp工具实现数据库表的快速导入操作,oracle数据库怎么用impdp导入.dmp文件,Oracle数据导入导出imp/exp命令 10g以上expdp/impdp命令 详细的 详细的 谢谢的信息别忘了在本站进行查找喔。
成都网站推广找创新互联,老牌网站营销公司
成都网站建设公司创新互联(www.cdcxhl.com)专注高端网站建设,网页设计制作,网站维护,网络营销,SEO优化推广,快速提升企业网站排名等一站式服务。IDC基础服务:云服务器、虚拟主机、网站系统开发经验、服务器租用、服务器托管提供四川、成都、绵阳、雅安、重庆、贵州、昆明、郑州、湖北十堰机房互联网数据中心业务。
分享题目:imp工具实现数据库表的快速导入操作 (imp指定表导入数据库)
URL地址:http://www.mswzjz.com/qtweb/news26/193726.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联