搜尋
首頁資料庫mysql教程Oracle数据库的导入导出

Oracle数据库的导入导出 作者:赵磊 博客:http://elf8848.iteye.com 一、背景介绍 9i,10g,11g 支持Export 与 Import工具,以后的版本将不在支持。建议改用数据泵,数据泵是Export 与 Import工具加强。 Export 与 Import的操作是针对*.dmp文件的,是oracle专

Oracle数据库的导入导出


作者:赵磊

博客:http://elf8848.iteye.com

 

一、背景介绍 

 

9i,10g,11g 支持Export 与 Import工具,以后的版本将不在支持。建议改用数据泵,数据泵是Export 与 Import工具加强。

 

Export 与 Import的操作是针对*.dmp文件的,是oracle专有的二进制格式。适合从oracle导入到oracle。

 

Export 与 Import对于大数据量(上G) 的导入导出已不适合。

 

SQL Loader这种导入工具是针对文本文件的。适合从文本文件导入到oracle。是执行insert语句的插入原理

 

Direct Load工具,直接加载,是从oracle块对oracle块的导数据,速度很多,适合从oracle导入到oracle。

 

 

二、使用Export 与 Import工具 对数据导入导出

 

工具在oracle  bin 目录下的 exp.exe , imp.exe 这两个工具

可在客户端或服务端运行

 

2.1、导出*.dmp文件

 

2.1.1 exp的四种模式:

1、表模式,用于导出某张表。

2、用户模式,用于导出某用户的Schema。

3、表空间模式,用于导出表空间。表空间的是由数据文件组成的,把数据文件从当前库copy到目标库,在用exp工具从当前库导出这个表空间的字典信息再导入到目标库,分两步走。限制较多。

4、数据库模式。用于导出整个数据库,不适合大数据量。

 

2.1.2  导出例子

 

导出1--用户模式

exp 用户名/密码@网络服务名 file=d:/oralce_bak_20101001.dmp owner=用户名 log=d:/exp.log direct=y

file:导出的*.dmp文件输出到指定目录

owner:导出哪个用户的Schema

log:日志文件输了到指定目录 (可选)

direct:y表示直接导出 (可选) 速度比一般导出快一倍以上,默认n

rows:y表示同时导出数据 (可选),默认值y,n表示只导表结构

 

导出2--表模式

exp 用户名/密码@网络服务名 file=20101001.dmp tables=表名1,表名2 rows=y  log=exp.log

file:导出的*.dmp文件输出到当前目录

tables:指定导出的表名,可以是多个,用逗号分隔

rows:y表示同时导出数据 (可选),默认值y,n表示只导表结构

log:日志文件输了到当前目录 (可选)

 

导出3--数据库模式

exp 用户名/密码@网络服务名 file=20101001.dmp full=y rows=y  log=exp.log grants=y

file:导出的*.dmp文件输出到当前目录

full:导出整个库

rows:y表示同时导出数据 (可选),默认值y ,n表示只导库结构

log:日志文件输了到当前目录 (可选)

grants: y表示导出授权 (可选)

 

2.1.3  导出时的字符集处理

 在源数据库与目标数据库字符集不同时,会发生字符集转换

 四个地方的字符集要先整清楚

 1、源数据库的字符集

 2、exp工具所在环境的字符集,你很可能在windows xp上运行exp导出远程oracle数据库的数据。

 3、imp工具所在环境的字符集,你很可能在windows xp上运行imp向远程的oracle数据库导入数据。

 4、目标数据库的字符集

 按最坏的情况计算,上面4个地方的字符集都不一样,最多会发生3次字符集的转换。转换时字符集不兼容就会发生乱码。

 

 查看数据库的字符集,数据库是英文linux系统:

 select * from nls_database_parameters;

 在查询结果中找三个地方:

     NLS_LANGUAGE -- American

     NLA_TERRITORY -- America

     NLS_CHARACTEREST -- AL32UTF8

     说明是:美国 AL32UTF8

 

 查看exp,imp工具所在环境的字符集,是windows xp系统:

 看注册表:HKEY_LOCAL_MACHINE/SOFTWARE/ORACLE/可能有多个oracle,一般是KEY_OraClient10g_home1  到这里,看右侧,找NLS_LANG项的值是:简体中文ZHS16GBK。

 说明是: 简体中文ZHS16GBK

 

 由于上面两处字符集不同,在导出导入时,共会发生两次字符集转换,如果想避免转换,做如下修改:

 

 修改exp,imp工具所在环境的字符集

 在windows xp命令行输入:SET NLS_LANG=American_America.AL32UTF8

 与数据库的字符集一致,是上面英文linux系统中数据库字符集的三个名称的组合。

 

  如果源数据库与目标数据库字符集不同,但exp工具与源数据库字符集一致, imp工具与目标数据库符集一致, 那么会在imp读*.dmp文件时发生字符集转换。

 如果源数据库与目标数据库字符集不同,但exp,imp工具与源数据库字符集一致, 那么会在目标数据库接收*.dmp时发生字符集转换。

 

 2.1.4 导出的权限

 用户默认可导出自己的表,想导出别人的表或Schema,要有exp_full_database权限

 grant exp_full_database to 用户名

 

 

 

 

2.2导入*.dmp文件

2.2.1 imp的四种模式:

与exp工具一样有四种模式,详见上面的exp的四种模式。

 

2.2.2  导入例子

 

导入1--用户模式

imp 用户名/密码@网络服务名 file=d:/oralce_bak_20101001.dmp ignore=y  fromuser=从哪个用户 touser=导入到哪个用户 tables=表名1,表名2

file:指明*.dmp文件位置

ignore:y:表已存在就不用再创建表了直接导入。 n表示创建表再导入。   默认为n,(可选)

fromuser:从哪个用户来 (可选)

touser:导入到哪个用户 (可选)

tables:指定导入的表名,可以是多个,用逗号分隔 (可选)

 

导入2--表模式

imp 用户名/密码@网络服务名 tables=表名1,表名2 rows=y file=2010.dmp

tables:指定导入的表名,可以是多个,用逗号分隔

rows:y表示同时导出数据 (可选),默认值y,n表示只导表结构

file:导入当前目录的*.dmp文件到数据库

 

imp 用户名/密码@网络服务名 file=d:/oralce_bak_20101001.dmp  show=y

show: y表示不导入,只看看。可以看看*.dmp是从哪个版本的库导出来的,好像也能看字符集。

 

使用DBA身份导入,空格部分要加单引号

imp \'用户名/密码@网络服务名 AS SYSDBA\'   tables=表名1,表名2 rows=y file=2010.dmp

 

 

 2.2.4 导入的权限

 用户默认可导入自己的表,想导入别人的表或Schema,要有exp_full_database权限

 grant exp_full_database to 用户名

 

 

 

 

 

三、使用数据泵 对数据导入导出

 

数据泵是Export 与 Import工具加强,工具在oracle  bin 目录下的 expdp.exe , impdp.exe 两个工具

只能在服务端运行

 

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
什么是oracle asm什么是oracle asmApr 18, 2022 pm 04:16 PM

oracle asm指的是“自动存储管理”,是一种卷管理器,可自动管理磁盘组并提供有效的数据冗余功能;它是做为单独的Oracle实例实施和部署。asm的优势:1、配置简单、可最大化推动数据库合并的存储资源利用;2、支持BIGFILE文件等。

oracle怎么查询所有索引oracle怎么查询所有索引May 13, 2022 pm 05:23 PM

方法:1、利用“select*from user_indexes where table_name=表名”语句查询表中索引;2、利用“select*from all_indexes where table_name=表名”语句查询所有索引。

Oracle怎么查询端口号Oracle怎么查询端口号May 13, 2022 am 10:10 AM

在Oracle中,可利用lsnrctl命令查询端口号,该命令是Oracle的监听命令;在启动、关闭或重启oracle监听器之前可使用该命令检查oracle监听器的状态,语法为“lsnrctl status”,结果PORT后的内容就是端口号。

oracle全角怎么转半角oracle全角怎么转半角May 13, 2022 pm 03:21 PM

在oracle中,可以利用“TO_SINGLE_BYTE(String)”将全角转换为半角;“TO_SINGLE_BYTE”函数可以将参数中所有多字节字符都替换为等价的单字节字符,只有当数据库字符集同时包含多字节和单字节字符的时候有效。

oracle怎么删除sequenceoracle怎么删除sequenceMay 13, 2022 pm 03:35 PM

在oracle中,可以利用“drop sequence sequence名”来删除sequence;sequence是自动增加数字序列的意思,也就是序列号,序列号自动增加不能重置,因此需要利用drop sequence语句来删除序列。

oracle怎么查询数据类型oracle怎么查询数据类型May 13, 2022 pm 04:19 PM

在oracle中,可以利用“select ... From all_tab_columns where table_name=upper('表名') AND owner=upper('数据库登录用户名');”语句查询数据库表的数据类型。

oracle查询怎么不区分大小写oracle查询怎么不区分大小写May 10, 2022 pm 05:45 PM

方法:1、利用“LOWER(字段值)”将字段转为小写,或者利用“UPPER(字段值)”将字段转为大写;2、利用“REGEXP_LIKE(字符串,正则表达式,'i')”,当参数设置为“i”时,说明进行匹配不区分大小写。

Oracle怎么修改sessionOracle怎么修改sessionMay 13, 2022 pm 05:06 PM

方法:1、利用“alter system set sessions=修改后的数值 scope=spfile”语句修改session参数;2、修改参数之后利用“shutdown immediate – startup”语句重启服务器即可生效。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
2 週前By尊渡假赌尊渡假赌尊渡假赌
倉庫:如何復興隊友
1 個月前By尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
4 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

SublimeText3 英文版

SublimeText3 英文版

推薦:為Win版本,支援程式碼提示!

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境