在java里怎么调用exp文件把数据库数据备份

在java里怎么调用exp文件把数据库数据备份,第1张

oracle 数据库导入导出(用dmp的方法) cmd 一 将数据库SampleDB完全导出,用户名system 密码manager 导出到E:\SampleDBdmp中 exp file=E:\sampleDBdmp full=y 二将备份数据库文件中的数据导入指定的数据库SampleDB 中,如果 SampleDB 已存在该表,则不再导入; imp file=D:\SampleDBdmp full=y ignore=y 如果没有DBA权限,用以下命令授予DBA权限 sqlplus / as sysdba; conn system/manager sql>grant dba to SampleD

EXPDP USERID='SYS/cuc2009@cuc as sysdba' schemas=sybj directory=DATA_PUMP_DIR dumpfile=dagdmp logfile=daglogversion=11021\x0d\IMPDP USERID='SYS/sys@daggis as sysdba' schemas= sybj directory=DATA_PUMP_DIRdumpfile=dagdmp logfile=daglog version=11021\x0d\可以是试试 我导出的是11g往10g导入成功了\x0d\但是表空间和用户名必须一致

汗。 如果你用imp可以导入成功,说明这个dmp文件是由exp命令导出的。 使用exp导出的文件只能用imp导入。 使用expdp导出的文件才可以用impdp导入。 这两种方法导出的文件完全是两码事,不可以混淆

问题一:怎么把sql文件导入mysql数据库 先打开cmd再进入mysql的bin目录:
cd D:\soft\wamp\bin\mysql\mysql5051b\bin 回车
mysql -u 用户名 -p 密码 回车
source d:\abcsql (指向你自己的目录)回车
ok!

问题二:请问xls数据文件怎么导入到mysql里啊? 1需要在mysql管理工具上面新建一个表,也可以用mysql命令创建,表建立完成之后,你需要将表中的字段名字告诉给填写excel表的人员
2打开excel表,按照程序提供的字段填写相应的数据此时注意下面几点:名字(我用红色标示出来了)需要跟程序提供的一样,其他的描述,表头可以不写都行
3使用的mysql管理工具是Navicat for MySQL,打开工具,选择表所在的数据库,然后点击数据库名字,右键数据,出来下拉菜单选择import wizard ,有汉化版本的更明确d出一个选择界面,我们选择excel file文件
4点击next(下一步),我们选择我们对应的excel文件就行,然后再下面选在我们的文件内容在哪一个sheet中,也就是你的内容写在excel什么地方,这点需要注意,也是关键的地方,我的内容在sheet3中,所以我选择sheet3
5点击next (此步骤也是关键步骤),需要注意2点: 1:filed name row 就是你的字段所在excel中的位置,也就是第几行(简单办法,一般就是英文对应的那一列)2:first data row(从哪一行开始执行),数据从哪一行开始呢,我这里选择的是3,4
6点击next 选择 target table 目标对应的数据库,选择你要导入到哪个数据库中表中
7如果到上面一步没有问题的话,我们默认next到最后 就行了然后打开表就能看到数据跟excel表中的一样。

问题三:sql文件怎么导入mysql数据库 直接执行
mysql -uroot -pPassword 问题四:oracle中怎样导入数据库文件 导出
导出具体的分为:导出表,导出方案,导出数据库三种方式。
导出使用exp命令来完成的,该命令常用的选项有:
userid: 用于指定执行导出 *** 作的用户名,口令,连接字符串
tables: 用于指定执行导出 *** 作的表
owner: 用于指定执行导出 *** 作的方案
full=y: 用于指定执行导出 *** 作的数据库
inctype: 用于指定执行导出 *** 作的增量类型
rows: 用于指定执行导出 *** 作是否要导出表中的数据
file: 用于指定导出文件名
Oracle 笔记
23

导出表
1导出自己的表
exp [email protected] tables=(emp,dept) file=d:\e1dmp
2导出其它方案的表
如果用户要导出其它方案的表,则需要dba的权限或是exp_full_database的权限,比如system就可以导出scott的表
E:\oracle\ora92\bin>exp [email protected] tables=(scottemp) file=d:\e2emp
特别说明:在导入和导出的时候,要到oracle目录的bin目录下。
3 导出表的结构
exp [email protected] tables=(emp) file=d:\e3dmp rows=n
4 使用直接导出方式
exp [email protected] tables=(emp) file=d:\e4dmp direct=y
这种方式比默认的常规方式速度要快,当数据量大时,可以考虑使用这样的方法。
这时需要数据库的字符集要与客户端字符集完全一致,否则会报错
导出方案
导出方案是指使用export工具导出一个方案或是多个方案中的所有对象(表,索引,约束)和数据。并存放到文件中。
1 导出自己的方案
exp [email protected] owner=scott file=d:\scottdmp
2 导出其它方案
如果用户要导出其它方案,则需要dba的权限或是exp_full_database的权限,比如system用户就可以导出任何方案
exp [email protected] owner=(system,scott) file=d:\systemdmp
导出数据库
导出数据库是指利用export导出所有数据库中的对象及数据,要求该用户具有dba的权限或者是exp_full_database权限
增量备份(好处是第一次备份后,第二次备份就快很多了)
exp [email protected] full=y inctype=plete file=d:\alldmp
导入
介绍
导入就是使用工具import将文件中的对象和数据导入到数据库中,但是导入要使用的文件必须是export所导出的文件。与导
出相似,导入也分为导入表,导入方案,导入数据库三种方式。
imp常用的>>

问题五:mdf数据库文件如何导入数据库 打开企业管理器->向下展开到&哗39;数据库'->右键点击'数据库'->选择'所有任务'->点击'附加数据库'->点击 带三个点的按钮()->找到要附加的数据库(要选择后缀名mdf的)->点击确定->点击确定 附加成功

问题六:想把文件存入数据库怎么办 数据库是不会存储文件的,他只是存储文件的存放地址,比如你想存储一个文件,你可以把文件名,文件大小,文件格式,文件存储的地址(d:/file/fieltxt)存到数据库表中。
当你想获取文件的时候就直接读取文件的存储地址File file=new File(d:/file/fieltxt);,这样就能存储数据文件了

问题七:如何导入sql脚本文件 sql的文件是很多数据库连接工具可以直接打开的文件,例如sqldevelop,pl/sql等。登陆数据库后,点击左上角的文件->打开 ,打开相应的sql文件就可以了,然后点击执行脚本。

问题八:300兆的sql文件如何导入mysql数据库中 抄一段给你看看,应该有些帮助。
一般网站经常用phpmyadmin备份和恢复数据库,但默认总是限制了16M。网站数据一多就不行了。
解决方法如下:
(1)修改phpini适用自己有服务器的人
大多数都修改phpini中的upload_max_filesize,但修改了这个以后,还是提示这个问题;
那么更改如下几处:
修改 PHPini
file_uploads on 是否允许通过>EXP/IMP备份(导出/导入备份)
exp hely=y 说明:
USERID 用户名/口令
FULL 导出整个文件 (N)
BUFFER 数据缓冲区的大小
OWNER 所有者用户名列表
FILE 输出文件 (EXPDATDMP)
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 输入文件 (EXPDATDMP)
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/xxxdmp log=xxxlog full=y commit=y ignore=y --全部导出
$ imp user/pwd file=/dir/xxxdmp log=xxxlog fromuser=dbuser touser=dbuser2 --全部导入

2指定用户全部导出
/home/oracle/product/9204/bin/exp userid=用户/密码 --说明:本地的数据库登入(可以指定其他数据库,则需添加@dbName)
owner=导出的用户名 file=导出路径存放目录dmp log=导出的日志信息log --主要:这是不能使用full=y或则会出错(默认该用户全导出)

3文件参数导出
$ exp parfile=usernamepar // 在参数文件中输入所需的参数
参数文件usernamepar 内容
userid=username/userpassword
buffer=8192000
compress=n
grants=y
file=/oracle/testdmp
full=y
4制定表导出(分区表导出及条件表导出)
$ exp user/pwd file=/dir/xxxdmp log=xxxlog tables=table1,table2 --或tables(table1,table2,)
$ exp user/pwd file=/dir/xxxdmp log=xxxlog tables=(T1: table1,T2: table2,) --T1是分区表
$ exp scott/tiger tables=emp query=/"where job=/'salesman/' and sal/<1600/" file=/directory/scott2dmp 或根据参数文件进行导出

5导入(一张或多张表)
$ imp user/pwd file=/dir/xxxdmp log=xxxlog tables=(table1,table2) fromuser=dbuser
touser=dbuser2 commit=y ignore=y
$ imp user/pwd file=/dir/xxxdmp log=xxxlog fromuser=dbuser touser=dbuser2
commit=y ignore=y

6只导出数据对象不导出数据
$ exp user/pwd file=/dir/xxxdmp log=xxxlog owner=user rows=n --rows=n/y说明是否导出数据行

7分割多个文件导出和导入
$ exp user/pwd file=1dmp,2dmp,3dmp,… filesize=1000m log=xxxlog full=y
$ imp user/pwd file=1dmp,2dmp,3dmp,… filesize=1000m tables=xxx fromuser=dbuser
touser=dbuser2 commit=y ignore=y

8增量导出和导入
a完全增量导出(inctype=complete) // 备份整个数据库
$ exp user/pwd file=/dir/xxxdmp log=xxxlog inctype=complete
b增量型增量导出 导出上一次备份后改变的数据(inctype=incremental)。
$ exp user/pwd file=/dir/xxxdmp log=xxxlog inctype=incremental
c累计型增量导出(Cumulative) 只导出自上次"完全"导出之后数据库中变化的信息。
$ exp user/pwd file=/dir/xxxdmp log=xxxlog inctype=cumulative
d增量导入:
$ imp usr/pwd FULL=y inctype=system/restore/inctype --(SYSTEM: 导入系统对象,RESTORE: 导入所有用户对象)

9使用sysdba进行导出和导入
1 命令行方式:
A: Windows平台:
C:/> exp 'sys/sys@instance as sysdba' tables=scottemp file=e:/empdmp
B: Unix & Linux平台(这时的"'"需要用到转义字符"/"):
$ exp /'sys/change_on_install@instance as sysdba/' tables=scottemp file=/home/oracle/empdmp
C: 表空间导入和导出
$ imp /'usr/pwd@instance as sysdba/' tablespaces=xx transport_tablespace=y
file=xxxdmp datafiles=xxxdbf
2 交互输入方式:
exp tables=scottemp --不输入连接字符串,直接回车
Export: Release 102030 - Production on Fri Jun 25 07:39:46 2004 Copyright (c) 1982, 2005, Oracle All rights reserved
Username: sys/change_on_install@instance as sysdba --输入连接字符串
3如果是写在参数文件中,则连接字符串需要用双引号了:USERID="sys/change_on_install@instance as sysdba"

10表空间传输(建议:10g以上使用,但我试了在9i没有找到相对应的检查表空是否传输的语句,10g 支持跨平台的表空间传输)
注意:
l索引在待传输表空间集中而表却不在。(注意,如果表在待传输表空间集中,而索引不在并不违反自包含原则,当然如果你坚持这样传输的话,会造成目标库中该表索引丢失)。
2分区表中只有部分分区在待传输表空间集(对于分区表,要么全部包含在待传输表空间集中,要么全不包含)。
3待传输表空间中,对于引用完整性约束,如果约束指向的表不在待传输表空间集,则违反自包含约束;但如果不传输该约束,则与约束指向无关。
4对于包含LOB列的表,如果表在待传输表空间集中,而Lob列不在,也是违反自包含原则的。
a查看表空间包含那些XML文件
select distinct ptablespace_name
from dba_tablespaces p, dba_xml_tables x, dba_users u, all_all_tables t
where ttable_name = xtable_name
and ttablespace_name = ptablespace_name
and xowner = uusername
b检测一个表空间是否符合传输标准的方法:
SQL > exec sysdbms_ttstransport_set_check('tablespace_name',true);
SQL > select from systransport_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=expdatdmp userid=”””sys/password as sysdba”””
transport_tablespace=y datafiles=(“c:/app_datadbf,c:/app_indexdbf”)
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 > expdmpgz
$ exp test/test tables=bitmap file=/home/newsys/testpipe &
gzip < /home/newsys/testpipe > bitmapdmpgz
3导出成功完成之后删除建立的管道
$ rm -rf /home/exppipe
4shell脚本可以这样写(我只是写主要的)
unix下:
mkfifo /home/exppipe
chmod a+rw exppipe
compress < exppipe > expdmpZ &
su -u oracle -c "exp userid=ll/ll file=/home/exppipe full=y buffer=20000000"
rm exppipe
linux下:
mknod /home/exppipe p
$ imp test/test file=/home/exppipe fromuser=test touser=macro &
gunzip < expdmpgz > /home/exppipe
$ rm –fr /home/exppipe

一般按照如下方法导入即可。

1、win键+R,输入cmd,打开命令提示符。

2、进入dmp文件所在目录。

3、执行imp导入语句:

imp 被导入用户名/密码@实例名 file=aaadmp log=aaalog fromuser=导出用户名

如图:

注意事项:导入的oracle版本需要与导出的oracle版本一致或高于导出的oracle版本,否则导入时会报错。


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

原文地址: http://outofmemory.cn/yw/10533787.html

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

发表评论

登录后才能评论

评论列表(0条)

保存