1.语法及使用说明 html
1.1 语法 sql
下面咱们来看一下SQL*Copy Command的语法及使用说明。 数据库
在解释SQL*Plus Copy Command的语法以前,咱们必需要明确SQL*Plus Copy Command不是一个方法或是函数,也不是一个SQL语句,它是一个命令(command),固然这个命令必须在SQL*Plus里运行。 服务器
SQL*Plus Copy Command的语法: 架构
COPY {FROM database | TO database | FROM database TO database} {APPEND|CREATE|INSERT|REPLACE} destination_table [(column, column, column, ...)] oracle
USING query 分布式
咱们分部分来解释一下: ide
COPY – 这个不太须要解释,主命令,声明要执行COPY操做 函数
From Database – 源数据库 工具
To Database – 目标数据库
此处注意花括号中有三种可选的写法(以”|”隔开),若是源数据表和目标数据表在同一个Schema中,则能够只写From Database,也能够只写To Database,固然还能够是第三种写法,把From Database和To Database写全。但若是源数据表和目标数据表不在同一个Schema中,则必须用第三种写法,即把From Database和To Database都写全
From Database和To Database的格式是同样的:USERID/PASSWORD@SID,这个你们都应该很熟悉了。
{APPEND|CREATE|INSERT|REPLACE} – 声明操做数据的方式,下面分别解释一下:
Append – 向已有的目标表中追加记录,若是目标表不存在,自动建立,这种状况下和Create等效。
Create – 建立目标表而且向其中追加记录,若是目标表已经存在,则会返回错误。
Insert – 向已有的目标表中插入记录,与Append不一样的是,若是目标表不存在,不自动建立而是返回错误。
Replace – 用查询出来的数据覆盖已有的目标表中的数据,若是目标表不存在,自动建立。
destination_table – 目标表的名字
[(column, column, column, ...)] – 能够指定目标表中列的名字,若是不指定,则自动使用Query中的列名。
USING query – 查询语句,交流的数据来自这儿。
备注:
1.这种方法适合小额数据的迁移,只能在SQL*PLUS中运行.
2.这种方法不能copy大对象的表,否则会抛异常"CPY0012: Object datatypes cannot be copied"
1.2 使用范例
下面咱们经过几个例子来看一下SQL*Plus Copy 命令的使用:
1.2.1 在同一个服务器的同一个Schema中复制数据:
同时指定From database和To database
SQL> copy from scott/tiger@lsj to scott/tiger@lsj create dept1 using select * from dept;
只指定From Database
SQL> copy from scott/tiger@lsj create dept2 using select * from dept;
只指定To Database
SQL> copy to scott/tiger@lsj create dept3 using select * from dept;
1.2.2 在同一个服务器的不一样Schema中复制数据:
这种状况下必须同时指定From Database和To Database
SQL> copy from scott/tiger@lsj to lsjdemo/lsjdemo@lsj create dept using select * from dept;
注意这种状况下,using select * from dept 中并不须要使用scott.demp的形式。
1.2.3 在不一样的服务器间复制数据:
SQL> conn lsj/lsj@sunserve
已链接。
SQL> copy from scott/tiger@lsj to lsj/lsj@sunserve create dept using select * from dept;
2.4 性能实验结果
实验数据:
记录数:5,082,500
数据量:504M
实验结果
方案------------------------执行时间(秒) ---------Undo(M) ------Redo(M)
Copy command -------------520.51----------------------0 ---------------- 592
Insert into…select …---- 631.64 ------------------345 -------------1720
Create Table…------------- 244.79 --------------------0 ----------------515
2.总结
Create Table…as select…是最快的,并且生成的Undo和Redo信息最少,因此只要可能,请尽可能使用这种方案。但这种方案有必定的限制,即目标表必须是不存在的,不能用它向已有的目标表中追加记录。
Insert into … select … 是最慢的,并且生成最多的Undo和Redo信息,对I/O的压力最大,优点在于你们对它比较熟悉,使用起来比较简单,适合于处理少许的数据,若要处理大量的数据,不推荐使用这种方案。
Copy Command能够处理Create Table不能处理的状况,即向已有的数据表中追加记录,相对于insert来讲,效率更高一些,生成更少的Redo信息,不生成Undo信息,因此在执行大量的数据追加时,推荐使用Copy Command命令。
Oracle Database 10g之后引入了最新的数据泵(Data Dump)技术,使DBA或开发人员能够将数据库元数据(对象定义)和数据快速移动到另外一个oracle数据库中。
数据泵导出导入(EXPDP和IMPDP)的做用
一、实现逻辑备份和逻辑恢复。
二、在数据库用户之间移动对象。
三、在数据库之间移动对象
四、实现表空间搬移。
数据泵导出导入与传统导出导入的区别:
在10g以前,传统的导出和导入分别使用EXP工具和IMP工具,从10g开始,不只保留了原有的EXP和IMP工具,还提供了数据泵导出导入工具EXPDP和IMPDP.使用EXPDP和IMPDP时应该注意的事项;
EXP和IMP是客户段工具程序,它们既能够在客户端使用,也能够在服务器段使用。
EXPDP和IMPDP是服务端的工具程序,他们只能在ORACLE服务端使用,不能在客户端使用
IMP只适用于EXP导出文件,不适用于EXPDP导出文件;IMPDP只适用于EXPDP导出文件,而不适用于EXP导出文件。
今天我在导入同事给个人数据文件时,老是报IMP-00038错误,提示,没法转换为环境字符集句柄,形成这种错误的缘由通常是数据库版本不匹配,可是咱们使用的都是oracle11g,就排除了这种可能。最后发现缘由是他是使用数据泵导出的数据文件,而我使用传统imp命令导入是不能够的,后续改成使用impdp数据泵导入成功。
下面是我使用数据泵导入数据文件的完整过程:
一、使用system用户登陆数据库,建立新用户usertest(新建用户时用户名最好和数据文件导出时的用户名相同),表空间可使用系统默认的也能够本身新建一个表空间。sql代码以下:
新建用户使用oracle默认表空间:
create user usertest identified by usertest;
新建表空间:
create tablespace user_all
datafile 'D:/dev/oracle/tablespace/user_all.dbf'
size 300M
autoextend on
next 50M
maxsize unlimited
新建用户(设置默认表空间):
create user usertest identified by usertest default tablespace user_all;
二、对新建的用户赋权限,dba、connect、resource。sql代码以下:
grant connect, resource,dba to usertest;
三、为数据库导入导出,新建目录文件 如dumpdir
create directory 目录名称 as '数据库服务器上的一个目录',如:
create directory dumpdir as 'd:\服务器目录名';
将导入或导出的文件放在这个目录下
四、为此用户的导入导出目录赋读写权限
grant read,write on directory dumpdir to usertest;
五、导出及导入
以SID=orcl,导出dmp的帐号为usertest,导入dmp的帐号为usertest为例。
若将数据从sfz中导出:
expdp usertest/usertest@orcl directory=dumpdir dumpfile=导出文件名
导入到usertest中:
impdp usertest/usertest@orcl directory=dumpdir dumpfile=导出文件名.dmp
导入导出用户名最好相同,用户名不一样时,还须要作个映射
remap_schema=test:usertest
注意在使用本地数据库时,要启动如下oracle服务:
OracleOraDb11g_home1TNSListener
OracleServiceORCL
若是只是链接远程服务器上的数据库,仅使用PL/SQL工具,那么能够把服务全停,这样能省点内存。
今天说说Oracle数据库的导入(imp.exe)和导出(exp.exe)命令的使用,咱们的电脑里面安装完Oracle或OracleClient的时候,在咱们的安装目录里面就有这两个命令了,通常是在你的Oracle安装目录下面的bin文件夹下面会有exp.exe和imp.exe这两个文件,它们都是在命令行下运行,首先打开你的CMD程序,而后切换到Oracle的bin目录下面。下面就看看这两个命令的具体用法:
基本语法和实例:
一、EXP:
有三种主要的方式(彻底、用户、表)
一、彻底:
EXP SYSTEM/MANAGER BUFFER=64000 FILE=C:\FULL.DMP FULL=Y
若是要执行彻底导出,必须具备特殊的权限
二、用户模式:
EXP SONIC/SONIC BUFFER=64000 FILE=C:\SONIC.DMP OWNER=SONIC
这样用户SONIC的全部对象被输出到文件中。
三、表模式:
EXP SONIC/SONIC BUFFER=64000 FILE=C:\SONIC.DMP OWNER=SONIC TABLES=(SONIC)
这样用户SONIC的表SONIC就被导出
二、IMP:
具备三种模式(彻底、用户、表)
一、彻底:
IMP SYSTEM/MANAGER BUFFER=64000 FILE=C:\FULL.DMP FULL=Y
二、用户模式:
IMP SONIC/SONIC BUFFER=64000 FILE=C:\SONIC.DMP FROMUSER=SONIC TOUSER=SONIC
这样用户SONIC的全部对象被导入到文件中。必须指定FROMUSER、TOUSER参数,这样才能导入数据。
三、表模式:
EXP SONIC/SONIC BUFFER=64000 FILE=C:\SONIC.DMP OWNER=SONIC TABLES=(SONIC)
这样用户SONIC的表SONIC就被导入。
ORACLE数据库有两类备份方法。第一类为物理备份,该方法实现数据库的完整恢复,但数据库必须运行在归挡模式下(业务数据库在非归挡模式下运行),且须要极大的外部存储设备,例如磁带库;第二类备份方式为逻辑备份,业务数据库采用此种方式,此方法不须要数据库运行在归挡模式下,不但备份简单,并且能够不须要外部存储设备。
数据库逻辑备份方法
ORACLE数据库的逻辑备份分为三种模式:表备份、用户备份和彻底备份。
表模式
备份某个用户模式下指定的对象(表)。业务数据库一般采用这种备份方式。
若备份到本地文件,使用以下命令:
exp icdmain/icd rows=y indexes=n compress=n buffer=65536
feedback=100000 volsize=0
file=exp_icdmain_csd_yyyymmdd.dmp
log=exp_icdmain_csd_yyyymmdd.log
tables=icdmain.commoninformation,icdmain.serviceinfo,icdmain.dealinfo
若直接备份到磁带设备,使用以下命令:
exp icdmain/icd rows=y indexes=n compress=n buffer=65536
feedback=100000 volsize=0
file=/dev/rmt0
log=exp_icdmain_csd_yyyymmdd.log
tables=icdmain.commoninformation,icdmain.serviceinfo,icdmain.dealinfo
注:在磁盘空间容许的状况下,应先备份到本地服务器,而后再拷贝到磁带。出于速度方面的考虑,尽可能不要直接备份到磁带设备。
用户模式
备份某个用户模式下的全部对象。业务数据库一般采用这种备份方式。
若备份到本地文件,使用以下命令:
exp icdmain/icd owner=icdmain rows=y indexes=n compress=n buffer=65536
feedback=100000 volsize=0
file=exp_icdmain_yyyymmdd.dmp
log=exp_icdmain_yyyymmdd.log
若直接备份到磁带设备,使用以下命令:
exp icdmain/icd owner=icdmain rows=y indexes=n compress=n buffer=65536
feedback=100000 volsize=0
file=/dev/rmt0
log=exp_icdmain_yyyymmdd.log
注:若是磁盘有空间,建议备份到磁盘,而后再拷贝到磁带。若是数据库数据量较小,可采用这种办法备份。
如下为详细的导入导出实例:
1、数据导出:
一、 将数据库TEST彻底导出,用户名system 密码manager 导出到D:\daochu.dmp中
exp system/manager@TEST file=d:\daochu.dmp full=y
二、 将数据库中system用户与sys用户的表导出
exp system/manager@TEST file=d:\daochu.dmp owner=(system,sys)
三、 将数据库中的表table1 、table2导出
exp system/manager@TEST file=d:\daochu.dmp tables=(table1,table2)
四、 将数据库中的表table1中的字段filed1以"00"打头的数据导出
exp system/manager@TEST file=d:\daochu.dmp tables=(table1) query=\" where filed1 like '00%'\"
上面是经常使用的导出,对于压缩我不太在乎,用winzip把dmp文件能够很好的压缩。
不过在上面命令后面 加上 compress=y 就能够了
2、数据的导入
一、将D:\daochu.dmp 中的数据导入 TEST数据库中。
imp system/manager@TEST file=d:\daochu.dmp
上面可能有点问题,由于有的表已经存在,而后它就报错,对该表就不进行导入。
在后面加上 ignore=y 就能够了。
2 将d:\daochu.dmp中的表table1 导入
imp system/manager@TEST file=d:\daochu.dmp tables=(table1)
基本上上面的导入导出够用了。很多状况我是将表完全删除,而后导入。
注意:
若是你的密码中包含特殊字符,在Windows下就须要用三个双引号扩起来,如:
exp skytf/"""#$adf`%6^=dfom"""@skytf buffer=52428800 file=skytf.dmp
若是是在Linux系统下,则密码用一对双引号, 总体userid和password用对单引号括住,如:
exp 'skytf/"?`}:=*H"@skytf'"<akJWI-q-@#<>?`}:Q*H"@skytf' DIRECT=Y buffer=52428800 FEEDBACK=10000 statistics=none file=skytf.dmp
密码中包含特殊字符的使用,具体请看《Oracle密码中含有特殊字符时exp,imp的使用》文章
你要有足够的权限,权限不够它会提示你。
数据库时能够连上的。能够用tnsping TEST 来得到数据库TEST可否连上。
出处:http://www.cnblogs.com/yugen/archive/2010/07/25/1784763.html
============================================================
假设我如此写导出语句:exp aaa/abc@oracle file=a.dmp full=y; 与 exp aaa/abc@oracle file=a.dmp (即不加full=y语句)导出的数据文件有什么区别呢?
(假设在数据库实例中还有bbb、ccc、ddd用户;数据库还有ora、oracl实例)能说得详细一些吗?谢谢了!!
-------------------------------
1.若是加上“full=y”,将整个数据库所有导出,须要特殊的权限(具体什么权限没研究过),通常用system用户就足够了,普通用户是不能够的
2.不加“full=y”,默认导出链接数据库的用户数据库对象,好比:exp aaa/abc@oracle file=a.dmp,导出aaa模式下的全部数据库对象
3.你说的有多个用户,可使用system来指定导出哪一个用户的数据库对象,好比:exp aaa/abc@oracle file=a.dmp owner=(bbb,ccc),普通用户是不能够指定owner的
4.数据有多个实例的状况,这个要看你“@”后面是什么,若是@oracle,则在oracle实例上进行导出,@ora,则在ora实例上进行导出
FULL 导出整个数据库 默认是禁止的
不加的就是不导出整个数据库 只导出该用户下的数据 那么bbb用户的数据就不会导出来。
能够按下面测试:
exp aaa/abc@oracle file=a.dmp full=y;
exp aaa/abc@oracle file=b.dmp;
Oracle10g提出的数据泵技术,在如下几个方面优于exp/imp命令:
一、数据泵工具运行于服务器端,相比客户端的exp/imp其性能更好,并能实现exp/imp的所有功能。
二、经过使用exclude,include,content等参数,数据泵能够为数据及数据对象提供更细微级别的选择性。
三、经过设定数据库版本号,数据泵能够兼容老版本的数据库系统。
四、并行执行。
五、经过estimate_only参数,数据泵能够预估导出做业所需的磁盘空间。
六、支持分布式环境中经过数据库链接实现导入\导出。
七、支持导入时从新映射功能(即将对象导入到新的目标数据文件、架构及表空间等)。
八、支持元数据压缩及数据采样。