湖南网站建设优化,wordpress主题 怎么安装,网站推广朋友圈文案,html5代码模板oracle11g数据库导入导出#xff1a; ①:传统方式——exp(导出)和(imp)导入#xff1a; ②:数据泵方式——expdp导出和#xff08;impdp#xff09;导入; ③:第三方工具——PL/sql Develpoer; 一、什么是数据库导入导出#xff1f; oracle11g数据库的导入/导出#xff0c…oracle11g数据库导入导出 ①:传统方式——exp(导出)和(imp)导入 ②:数据泵方式——expdp导出和impdp导入; ③:第三方工具——PL/sql Develpoer; 一、什么是数据库导入导出 oracle11g数据库的导入/导出就是我们通常所说的oracle数据的还原/备份。 数据库导入:把.dmp 格式文件从本地导入到数据库服务器中(本地oracle测试数据库中); 数据库导出:把数据库服务器中的数据(本地oracle测试数据库中的数据),导出到本地生成.dmp格式文件。 .dmp 格式文件就是oracle数据的文件格式(比如视频是.mp4 格式,音乐是.mp3 格式); 二、二者优缺点描述 1.exp/imp: 优点:代码书写简单易懂,从本地即可直接导入不用在服务器中操作降低难度减少服务器上的操作也就 保证了服务器上数据文件的安全性。 缺点这种导入导出的速度相对较慢合适数据库数据较少的时候。如果文件超过几个G大众性能的电 脑至少需要4~5个小时左右。 2.expdp/impdp: 优点:导入导出速度相对较快,几个G的数据文件一般在1~2小时左右。 缺点:代码相对不易理解,要想实现导入导出的操作必须在服务器上创建逻辑目录(不是真正的目录)。我们 都知道数据库服务器的重要性所以在上面的操作必须慎重。所以这种方式一般由专业的程序人员来完 成(不一定是DBA(数据库管理员)来干,中小公司可能没有DBA)。 3.PL/sql Develpoer: 优点封装了导入导出命令无需每次都手动输入命令。方便快捷提高效率。 缺点长时间应用会对其产生依赖降低对代码执行原理的理解。 三、特别强调 目标数据库:数据即将导入的数据库(一般是项目上正式数据库); 源数据库:数据导出的数据库(一般是项目上的测试数据库); 1.目标数据库要与源数据库有着名称相同的表空间。 2.目标数据在进行导入时用户名尽量相同(这样保证用户的权限级别相同)。 3.目标数据库每次在进行数据导入前应做好数据备份以防数据丢失。 4.使用数据泵时,一定要现在服务器端建立可用的逻辑目录并检查是否可用。 5.弄清是导入导出到相同版本还是不同版本(oracle10g版本与oracle11g版本)。 6.目标数据导入前,弄清楚是数据覆盖(替换),还是仅插入新数据或替换部分数据表。 7.确定目标数据库磁盘空间是否足够容纳新数据是否需要扩充表空间。 8.导入导出时注意字符集是否相同一般Oracle数据库的字符集只有一个并且固定一般不改变。 9.导出格式介绍: Dmp格式.dmp是二进制文件可跨平台还能包含权限效率好 Sql格式.sql格式的文件可用文本编辑器查看通用性比较好效率不如第一种 适合小数据量导入导出。尤其注意的是表中不能有大字段 blob,clob,long如果有会报错 Pde格式.pde格式的文件.pde为PL/SQL Developer自有的文件格式只能用PL/SQL Developer工具 导入导出不能用文本编辑器查看 10.确定操作者的账号权限。 四、二者的导入导出方法 1、传统方法 通用命令:exp(imp) username/passwordSERVICENAME:1521 file“e:\temp.dmp” full y; 数据库导出举例:
exp xinxiaoyong/123456127.0.0.1:1521 file“e:\temp.dmp” full y; exp:导出命令导出时必写。 imp:导入命令导入时必写,每次操作二者只能选择一个执行。 username:导出数据的用户名必写; password:导出数据的密码必写; :地址符号必写; SERVICENAME:Oracle的服务名必写; 1521:端口号1521是默认的可以不写,非默认要写; file“e:\temp.dmp” : 文件存放路径地址必写; fully :表示全库导出。可以不写则默认为no,则只导出用户下的对象; 方法细分 1.完全导入导出 exp(imp) username/passwordSERVICENAME:1521 file“e:\temp.dmp” full y; 2.部分用户表table导入导出 exp(imp) username/passwordSERVICENAME:1521 file“e:\temp.dmp” tabels (table1,table2,table3,…); 3.表空间tablespaces导入导出 //一个数据库实例可以有N个表空间(tablespace)一个表空间下可以有N张表(table)。 exp(imp) username/passwordSERVICENAME:1521 file“e:\temp.dmp” tablespaces (tablespace1,tablespace2,tablespace3,…); 4.用户名username对象导入导出 exp(imp) username/passwordSERVICENAME:1521 file“e:\temp.dmp” owner(username1,username2,username3); 2、数据泵方法 创建directory: expdp(impdp) username/passwordSERVICENAME:1521 schemasusername dumpfilefile1.dmp logfilefile1.log directorytestdata1 remap_schematest:test; 数据库导出举例: expdp xinxiaoyong/123456127.0.0.1:1521 schemasxinxiaoyong dumpfiletest.dmp logfiletest.log directorytestdata1;
exp:导出命令导出时必写。 imp:导入命令导入时必写,每次操作二者只能选择一个执行。 username:导出数据的用户名必写; password:导出数据的密码必写; :地址符号必写; SERVICENAME:Oracle的服务名必写; 1521:端口号1521是默认的可以不写,非默认要写; schemas导出操作的用户名; dumpfile导出的文件; logfile:导出的日志文件,可以不写 directory:创建的文件夹名称; remap_schema源数据库用户名:目标数据库用户名,二者不同时必写相同可以省略; 1.查看表空间 select form dba_tablespaces; 2.查看管理理员目录(同时查看操作系统是否存在因为Oracle并不关心该目录是否存在如果不存 在则出错)。 select form dba_directories; 3.创建逻辑目录该命令不会在操作系统创建真正的目录最好以system等管理员创建。 create directory testdata1 as ‘d:\test\dump’; 4.给xinxiaoyong用户赋予在指定目录的操作权限最好以system等管理员赋予。 //xinxiaoyong 是用户名(123456是用户密码) grant read,write on directory testdata1 to xinxiaoyong; 5.导出数据
1)按用户导 expdp xinxiaoyong/123456orcl schemasxinxiaoyong dumpfileexpdp.dmp directorytestdata1; 2)并行进程parallel expdp xinxiaoyong/123456orcl directorytestdata1 dumpfilexinxiaoyong3.dmp parallel40 job_namexinxiaoyong3 3)按表名导 expdp xinxiaoyong/123456orcl tablesemp,dept dumpfileexpdp.dmp directorytestdata1; 4)按查询条件导 expdp xinxiaoyong/123456orcl directorytestdata1 dumpfileexpdp.dmp tablesemp query‘WHERE deptno20’; 5)按表空间导 expdp system/manager directorytestdata1 dumpfiletablespace.dmp tablespacestemp,example; 6)导整个数据库 expdp system/manager directorytestdata1 dumpfilefull.dmp FULLy; 6.还原数据 1)导到指定用户下 impdp xinxiaoyong/123456 directorytestdata1 dumpfileexpdp.dmp schemasxinxiaoyong; 2)改变表的owner impdp system/manager directorytestdata1 dumpfileexpdp.dmp tablesxinxiaoyong.dept remap_schema xinxiaoyong:system; 3)导入表空间 impdp system/manager directorytestdata1 dumpfiletablespace.dmp tablespacesexample; 4)导入数据库 impdb system/manager directorydump_dir dumpfilefull.dmp FULLy; 5)追加数据 impdp system/manager directorytestdata1 dumpfileexpdp.dmp schemassystem table_exists_action; 3、PLSQL方法 登录plsql工具所使用用户为源数据库有导出权限exp_full_database,dba等的用户。 1.导出建表语句包括存储结构
导出步骤tools -export user object选择要导出的对象导出.sql格式文件并等待导出完成如 下图
导出数据文件 ; 2.导出步骤tools -export tables选择要导出的表及导出的格式进行导出。
导出为dmp格式如下图
导出为sql格式如下图
导出为pde格式如下图 提示说明采用第三方工具导出导入整个数据库的话耗时较长一定要有足够的时间来操作(数据量大的话需要好几个小时)。3.导入建表语句 导入步骤tools-import tables-SQL Inserts 导入.sql文件 4.导入数据 tools-import talbes然后再根据导出的数据格式选择导入dmp文件或者sql文件 或者pde文件。 提示说明导入之前最好把以前的表删除当然导入另外数据库除外。 另外导入时当发现进度条一直卡在一个点而且导出的文件不再增大时甚至是提示程序 未响应千万不要以为程序卡死了这个导入导出就是比较缓慢只要没有提示报错
或者导入完成就不要停止程序。
CREATE OR REPLACE DIRECTORY mydir AS ‘D:\mydir’;–创建逻辑目录mydir –在windows的同一位置建立一个文件也就是d盘下面把dmp文件放在下面 Impdp wiicare/123456wiicare directorymydir dumpfileWIICARE.DMP 按照账号密码 导入指定的数据文件 remap_tablespace将一个表空间映射到另一个表空间 TSP_WIICARE:wiicare remap_schema将一个方案中的对象放到另一个方案中 wiicarebase:wiicare
导出exp exp wlj/wljorcl filed:exportoracle.dmp fully 账号密码。导出库到d盘下名字叫做exportoracle.dmp 导出数据泵