- 浏览: 216851 次
- 性别:
- 来自: 广州
文章分类
最新评论
-
chen569844962:
博主,你好,这个代码貌似不太完整,不知道能不能共享一下带我给我 ...
JTable 导出 Excel 利用 jxl.jar -
z995204127:
我去,发多了,太激动
【原创】swing 按钮点击 调用swt窗口(SWT浏览器)browser -
z995204127:
楼主,我去,太尼玛给力了,我搞了一天没搞定,原来要用一个线程包 ...
【原创】swing 按钮点击 调用swt窗口(SWT浏览器)browser -
z995204127:
楼主,我去,太尼玛给力了,我搞了一天,原来要用一个线程包装下。 ...
【原创】swing 按钮点击 调用swt窗口(SWT浏览器)browser -
changhuzhao:
好用!
org/eclipse/ui/internal/util/SWTResourceUtil
转载:Oracle exp/imp备份(导出/导入备份)
ORACLE 2008-12-19 11:28:13 阅读15 评论0 字号:大 中 小
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 选定导出表子集的子句
下列关 键字仅用于可传输的表空间
TRANSPORT_TABLESPACE 导出可传输的表空间元数据 (N)
TABLESPACES 将传输的表空间列表
imp hely=y 说明:
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)
下列关键字仅用于可传输的表空间
TRANSPORT_TABLESPACE 导入可传输的表空间元数据 (N)
TABLESPACES 将要传输到数据库的表空间
DATAFILES 将要传输到数据库的数据文件
TTS_OWNERS 拥有可传输表空间集中数据的用户
导入注意事项:
(1) 数据库对象已经存在
一般情况, 导入数据前应该彻底删除目标数据下的表, 序列, 函数/过程,触发器等;
数据库对象已经存 在, 按缺省的imp参数, 则会导入失败
如果用了参数ignore=y, 会把exp文件内的数据内容导入
如果表有唯一关键字 的约束条件, 不合条件将不被导入
如果表没有唯一关键字的约束条件, 将引起记录重复
(2) 数据库对象有主外键约束
不符合主外键约束时, 数据会导入失败
解决办法: 先导入主表, 再导入依存表
disable目标导入对象的 主外键约束, 导入数据后, 再enable它们
(3) 权限不够
如果要把A用户的数据导入B用户下, A用户需要有imp_full_database权限
(4) 导入大表( 大于80M ) 时, 存储分配失败
默认的EXP时, compress = Y, 也就是把所有的数据压缩在一个数据块上.
导入时, 如果不存在连续一个大数据块, 则会导入失败.
导出80M以上的大表时, 记得compress= N, 则不会引起这种错误.
(5) imp和exp使用的字符集不同
如果字符集不同, 导入会失败, 可以改变unix环境变量或者NT注册表里NLS_LANG相关信息.
导入完成后再改回来.
(6) imp和exp版本不能往上兼容
imp可以成功导入低版本exp生成的文件, 不能导入高版本exp生成的文件
使用方法:
例题格式及说明:
1.普通数据库全部导出和导入
exp 用户/密码@dbName
file=路径.dmp full=y --还有其他的参数,看需要进行填写
$ exp user/pwd
file=/dir/xxx.dmp log=xxx.log full=y commit=y ignore=y --全部导出
$
imp user/pwd file=/dir/xxx.dmp log=xxx.log fromuser=dbuser
touser=dbuser2 --全部导入
2.指定用户全部导出
/home/oracle/product/9.2.0.4/bin/exp
userid=用户/密码 --说明:本地的数据库登入(可以指定其他数据库,则需添加@dbName)
owner=导出的用户名
file=导出路径存放目录.dmp log=导出的日志信息.log --主要:这是不能使用full=y或则会出错(默认该用户全导出)
3.文件参数导出
$ exp parfile=username.par // 在参数文件中输入所需的参数
参
数文件username.par 内容
userid=username/userpassword
buffer=8192000
compress=n
grants=y
file=/oracle/test.dmp
full=y
4.制定表导出(分区表导出及条件表导出)
$ exp user/pwd file=/dir/xxx.dmp log=xxx.log
tables=table1,table2 --或tables(table1,table2,.....)
$ exp
user/pwd file=/dir/xxx.dmp log=xxx.log tables=(T1: table1,T2:
table2,.....) --T1是分区表
$ exp scott/tiger tables=emp query=\"where
job=\'salesman\' and sal\<1600\" file=/directory/scott2.dmp
或根据参数文件进行导出
5.导入(一张或多张表)
$ imp user/pwd
file=/dir/xxx.dmp log=xxx.log tables=(table1,table2) fromuser=dbuser
touser=dbuser2
commit=y ignore=y
$ imp user/pwd file=/dir/xxx.dmp log=xxx.log
fromuser=dbuser touser=dbuser2
commit=y ignore=y
6.只导出数据
对象不导出数据
$ exp user/pwd file=/dir/xxx.dmp log=xxx.log owner=user
rows=n --rows=n/y说明是否导出数据行
7.分割多个文件导出和导入
$ exp user/pwd
file=1.dmp,2.dmp,3.dmp,… filesize=1000m log=xxx.log full=y
$ imp
user/pwd file=1.dmp,2.dmp,3.dmp,… filesize=1000m tables=xxx
fromuser=dbuser
touser=dbuser2 commit=y ignore=y
8.增量导出和导入
a.
完全增量导出(inctype=complete) // 备份整个数据库
$ exp user/pwd
file=/dir/xxx.dmp log=xxx.log inctype=complete
b.增量型增量导出
导出上一次备份后改变的数据(inctype=incremental)。
$ exp user/pwd
file=/dir/xxx.dmp log=xxx.log inctype=incremental
c.累计型增量导出(Cumulative) 只导出自上次"完全"导出之后数据库中变化的信息。
$ exp user/pwd
file=/dir/xxx.dmp log=xxx.log inctype=cumulative
d.增量导入:
$
imp usr/pwd FULL=y inctype=system/restore/inctype --(SYSTEM:
导入系统对象,RESTORE: 导入所有用户对象)
9.使用sysdba进行导出和导入
1. 命令行方式:
A: Windows平台:
C:\> exp as sysdba'
tables=scott.emp file=e:\emp.dmp
B: Unix
& Linux平台(这时的"'"需要用到转义字符"\"):
$
exp \'sys/change_on_install@instance as sysdba\' tables=scott.emp
file=/home/oracle/emp.dmp
C: 表空间导入和导出
$ imp \'usr/pwd@instance as sysdba\' tablespaces=xx
transport_tablespace=y
file=xxx.dmp datafiles=xxx.dbf
2.
交互输入方式:
exp tables=scott.emp --不输入连接字符串,直接回车
Export: Release 10.2.0.3.0 - Production on Fri Jun 25 07:39:46 2004
Copyright (c) 1982, 2005, Oracle. All rights reserved.
Username: as sysdba --输入连接字符串.
3.如果是写在参数文件中,则连接字符串需要用双引号
了:USERID=" as sysdba"
10.表空间传输(建议:10g以上使用,但我试了在9i没有找到相对应的检查表空是
否传输的语句,10g 支持跨平台的表空间传输)
注意:
l.索引在待传输表空间集中而表却不在。(注意,如果表在待传输表空间集中,而索引不在并不违反自包含原则,当然如果你坚持这样传输的话,会造成目标库中
该表索引丢失)。
2.分区表中只有部分分区在待传输表空间集(对于分区表,要么全部包含在待传输表空间集中,要么全不包含)。
3.待传输表空间中,对于引用完整性约束,如果约束指向的表不在待传输表空间集,则违反自包含约束;但如果不传输该约束,则与约束指向无关。
4.对于包含LOB列的表,如果表在待传输表空间集中,而Lob列不在,也是违反自包含原则的。
a.查看表空间包含那些XML文件
select
distinct p.tablespace_name
from dba_tablespaces p, dba_xml_tables
x, dba_users u, all_all_tables t
where t.table_name =
x.table_name
and t.tablespace_name = p.tablespace_name
and
x.owner = u.username
b.检测一个表空间是否符合传输标准的方法:
SQL > exec
sys.dbms_tts.transport_set_check('tablespace_name',true);
SQL >
select * from sys.transport_set_violations;
c.简要使用步骤
1.设置表空间
为只读(假定表空间名字为APP_Data 和APP_Index)
SQL > alter tablespace
app_data read only;
SQL > alter tablespace app_index read
only;
2.发出EXP 命令
SQL> host exp userid='''sys/password as
sysdba''' transport_tablespace=y
tablespaces=(app_data,
app_index)
以上需要注意的是:(或则参考我自己写的 表空间导入和导出例题)
·为了在SQL中执行
EXP,USERID 必须用三个引号,在UNIX 中也必须注意避免"/"的使用
·在816 和以后,必须使用sysdba 才能操作
·
这个命令在SQL中必须放置在一行(这里是因为显示问题放在了两行)
3.拷贝.dbf数据文件(以及.dmp
文件)到另一个地点,即目标数据库可以是cp(unix)或copy(windows)或通过ftp 传输文件(一定要在bin方式)
4.
把本地的表空间设置为读写
$ alter tablespace app_data read write;
$
alter tablespace app_index read write;
5.在目标数据库附加该数据文件 (直接指定数据文件名)
(表空间不能存在,必须建立相应用户名或者用fromuser/touser)
$ imp file=expdat.dmp
userid=”””sys/password as sysdba”””
transport_tablespace=y
datafiles=(“c:\app_data.dbf,c:\app_index.dbf”)
tablespaces=app_data,app_index
tts_owners=hr,oe
6.设置目标数据库表空间为读写
$ alter tablespace
app_data read write;
$ alter tablespace app_index read write;
11.
优化IMP/EXP的速度(修改参数配置文件)
EXP:
加大large_pool_size,可以提高exp 的速度
采
用直接路径的方式(direct=y),数据不需要经过内存进行整合和检查.
设置较大的buffer,如果导出大对象,小buffer
会失败。
export文件不在ORACLE 使用的驱动器上,不要export到NFS 文件系统
UNIX环境:用管道模式
直接导入导出来提高imp/exp 的性能
IMP:
建立一个indexfile,在数据import完成后在建立索引
将
import 文件放在不同的驱动器上
增加DB_BLOCK_BUFFERS
增加LOG_BUFFER
用非归
档方式运行ORACLE:ALTER DATABASE NOARCHIVELOG;
建立大的表空间和回滚段,OFFLINE
其他回滚段,回滚段的大小为最大表的1/2
使用 COMMIT=N
使用ANALYZE=N
单用户模式导入
UNIX
环境:用管道模式直接导入导出来提高imp/exp 的性能
12.通过unix/Linux PIPE管道加快exp/imp速度
步骤如下:
通过管道导出数据:
1.通过mknod -p 建立管道
$ mknod
/home/exppipe p // 在目录/home下建立一个管道exppipe注意参数p
2.通过exp 和gzip
导出数据到建立的管道并压缩
$ exp test/test file=/home/exppipe & gzip <
/home/exppipe > exp.dmp.gz
$ exp test/test tables=bitmap
file=/home/newsys/test.pipe &
gzip <
/home/newsys/test.pipe > bitmap.dmp.gz
3.导出成功完成之后删除建立的管道
$
rm -rf /home/exppipe
4.shell脚本可以这样写(我只是写主要的)
unix下:
mkfifo
/home/exp.pipe
chmod a+rw exp.pipe
compress < exp.pipe
> exp.dmp.Z &
su -u oracle -c "exp userid=ll/ll
file=/home/exp.pipe full=y buffer=20000000"
rm exp.pipe
linux
下:
mknod /home/exppipe p
$ imp test/test
file=/home/exppipe fromuser=test touser=macro &
gunzip <
exp.dmp.gz > /home/exppipe
$ rm –fr /home/exppipe
发表评论
-
求助:Hibernate Integer问题
2011-01-15 10:43 2070Exception in thread "AW ... -
(转)Oracle数据库的迁移方法
2010-03-04 22:26 1076(转)Oracle数据库的迁移方法 本文转自:http:// ... -
Oracle 数据进行迁移
2010-03-04 22:00 907来源:中国it实验室 我们常常需要对数据进行迁移,迁移到更加 ... -
奇怪问题:Hibernate 无法更新(update)
2010-01-31 17:18 1598今天遇到一个很奇怪的问题,我用Hibernate,更新(upd ... -
从EXCEL导入数据到数据库,查询不到。
2010-01-22 16:01 1069public Object queryProvinceByNa ... -
JComboBox数据库连接 “省市县”三级联动显示
2009-11-30 21:13 2114iFrmPrProvice = new JComboBox() ... -
JComboBox组件如何能和数据库连接
2009-11-30 10:29 1089// ======================自动搜索 ... -
利用 Hibernate 储存经纬度 到 Oracle 的三种方法
2009-08-11 10:55 1713利用 Hibernate 储存经纬度 到 Oracle 的三种 ... -
解决:hibernate 实现空间数据库oracle spatial
2009-08-10 21:25 3813本来报错“无效列类型”,但是今天在“大强”“linlian ... -
分享 HQL 查询日期 Oracle
2009-08-08 21:21 2554今天为了查询Oracle里面的Date的字段,但是Ora ... -
救助:OpenSwing Framework
2009-07-20 19:26 1441最近用到了OpengSwing Framework ... -
hibernate 3.3.1 新特性
2009-07-18 21:05 1503Changes in version 3.3.1.GA (20 ... -
Oracle导入excel数据方法汇总
2009-07-09 17:31 1995摘要:在程序编制过程和数据汇总交换过程中,经常会碰到需要将其他 ... -
发现一个激动人心的网站 Hibernate Spatial
2009-06-28 17:07 1609你是否是开发空间数据库? 利用hibernate oracl ... -
折腾了好久 ORA-00904: : 无效的标识符
2009-06-28 11:48 4664建立完对象模型,用hibernate生成表的时候报错 ... -
oracle bfile blob
2009-06-20 23:53 1456首先,图片是binary格式 ... -
Hibernate查询方法与缓存的关系
2009-06-13 11:24 814在开发中,通 ... -
Hibernate二级缓存攻略
2009-06-13 10:53 930很多人对二级缓存都不太了解,或者是有错误的认识,我一直想写一篇 ... -
Hibernater 一级缓存
2009-06-11 20:48 866Hibernater 一级缓存: Hiberna ... -
org/eclipse/ui/internal/util/SWTResourceUtil
2009-06-11 20:47 3558eclipse3.4关于hibernate tools使用时, ...
相关推荐
Oracle 数据库的 EXP/IMP 工具是数据库管理员(DBA)进行数据迁移、备份和恢复的重要工具。本文将详细介绍这两个工具的使用方法。 一、导出工具 EXP 1. EXP 是一个操作系统级别的可执行文件,通常位于 ORACLE_HOME...
exp工具将这些信息写入一个.dmp文件,该文件可以在不同的Oracle环境之间传输,并使用imp工具重新导入。 22、exp语法和参数 exp命令支持多种参数,例如 owner(用户)、file(输出文件名)、log(日志文件)、tables...
通过对 Oracle 表空间创建命令的分析以及对 exp/imp2 导入导出工具的介绍,我们可以看到,在 Oracle 数据库管理中,合理配置表空间属性和灵活运用备份恢复工具对于保障数据的安全性和可靠性至关重要。希望本文能帮助...
Oracle exp/imp 是Oracle数据库系统提供的两个实用工具,用于数据的备份和恢复。exp(Export)用于导出数据库中的对象和数据,而imp(Import)则用于将这些导出的数据导入到另一个数据库中。在实际操作中,由于各种...
Oracle 19c 备份恢复-导入导出是指使用 Oracle 数据库提供的工具 exp 和 imp 实现数据库的备份恢复和数据的导入导出。本文将详细介绍 Oracle 19c 备份恢复-导入导出的基本命令、工作方式、模式、选项和高级选项。 ...
Oracle 导入导出(imp,exp 本机或异机恢复) Oracle 的数据库导入导出(imp/exp)是数据库管理员经常使用的两个命令,它们分别用于数据库的导出和导入。本文档总结了 Oracle 数据库的完全导入导出、imp 和 exp 命令...
exp 命令用于将数据库中的数据导出到文件中,而 imp 命令用于将文件中的数据导入到数据库中。 Oracle 数据库备份方法 Oracle 数据库有两类备份方法:物理备份和逻辑备份。物理备份方法实现数据库的完整恢复,但...
"Oracle 数据导入导出 imp/exp 命令详解" Oracle 数据导入导出 imp/exp 命令是 Oracle 数据库管理系统的重要组件之一,用于实现数据的导入和导出。imp/exp 命令可以将数据从远程数据库服务器导出到本地的 dmp 文件...
本文将详细介绍Oracle数据库的导入导出命令,包括exp和imp命令的使用方法和参数设置。 exp命令 exp命令是Oracle数据库的导出命令,用于将数据库中的数据导出到操作系统的文件中。exp命令的基本语法如下: ``` exp ...
在Oracle环境中,"exp"和"imp"是两个关键的实用程序,用于数据的导出(export)和导入(import)。在这个"oracleClient安装包exp和imp文件.zip"压缩包中,我们主要关注的是这两个工具以及它们在Oracle客户端11.2....
Oracle的expimp工具是Oracle数据库管理系统中用于数据迁移和备份的关键组件。它们分别代表了数据导出和导入的功能,能够帮助管理员将数据从一个数据库移动到另一个数据库,或者创建数据库的备份副本。以下是对这两个...
导入/导出是ORACLE幸存的最古老的两个命令行工具,其实我从来不认为Exp/Imp是一种好的备份方式,正确的说法是Exp/Imp只能是一个好的转储工具,特别是在小型数据库的转储,表空间的迁移,表的抽取,检测逻辑和物理...
Oracle 数据库导入导出(备份与恢复) Oracle 数据库导入导出是指将 Oracle 数据库中的数据导出到外部文件中,并将外部文件中的数据导入到 Oracle 数据库中。这种操作可以用于数据库备份、恢复、迁移和数据交换等...
总结:Oracle 数据库的导入导出技术可以使用 exp 和 imp 命令实现,这两个命令可以将数据库中的数据导出到文件中或者将文件中的数据导入到数据库中。这个过程可以用于数据库的备份和恢复、数据的迁移和同步等功能。