您的位置:首页 > 数据库 > Oracle

oracle 11g 含xmlType类型表的导入导出

2018-01-12 11:07 861 查看

常规导出报错

toad->数据库->导出->导出应用程序向导

EXP-00107: 不支持特征 (BINARY XML) (属于列 XML, 表 JS.TEST)。不会导出该表。


怎么解决?

在服务端用expdp、impdp

重头说起

测试机是centos7

启动docker 数据库实例

docker run -d  -p 49164:1521 --name=oracle11test  -e TZ=Asia/Shanghai  -v /home/oracledata/test:/u01/app/oracle  sath89/oracle-xe-11g

数据库名:XE
端口:49164
用户名:sys
密码:oracle


本地挂载数据目录

/home/oracledata/test

docker内实例数据目录

/u01/app/oracle

toad创建用户



指定表空间



授予connect,resource角色



oracle为兼容以前版本,提供三种标准角色(role):connect/resource和dba。角色说明

connect role(连接角色)
--临时用户,特指不需要建表的用户,通常只赋予他们connect role.
--connect是使用oracle简单权限,这种权限只对其他用户的表有访问权限,包括select/insert/update和delete等。
--拥有connect role 的用户还能够创建表、视图、序列(sequence)、簇(cluster)、同义词(synonym)、回话(session)和其他  数据的链(link)

resource role(资源角色)
--更可靠和正式的数据库用户可以授予resource role。
--resource提供给用户另外的权限以创建他们自己的表、序列、过程(procedure)、触发器(trigger)、索引(index)和簇(cluster)。

dba role(数据库管理员角色)
--dba role拥有所有的系统权限
--包括无限制的空间限额和给其他用户授予各种权限的能力。system由dba用户拥有


授予test用户使用目录备份的权限



我们备份的dmp文件存放在DATA_PUMP_DIR下

具体指向服务器目录

/u01/app/oracle/admin/XE/dpdump/

创建测试表

CREATE TABLE test.TEST
(
ID   VARCHAR2(1 BYTE),
XML  SYS.XMLTYPE
)
insert into test.test values(1,'<a></a>')


进入docker,准备导出导入

[root@node01 dpdump]# docker exec -it oracletest bin/bash

root@b22539d9043e:/#  expdp test/test@XE directory=DATA_PUMP_DIR TABLES=test dumpfile=test.dmp


注意test.dmp不能是已存在的文件,不然不会执行导出

将test表删除,不删除数据是不导入的

然后执行下面导入命令

impdp test/test@XE directory=DATA_PUMP_DIR dumpfile=test.dmp


成功!!!

导出整库的方法,全库导入导出需要角色

DATAPUMP_EXP_FULL_DATABASE

DATAPUMP_IMP_FULL_DATABASE

我直接给了一个dba角色,偷个懒

expdp test/test@XE DIRECTORY=DATA_PUMP_DIR DUMPFILE=full.dmp FULL=y
如果是备份库要提前建好test用户并授予导入角色,目录权限
impdp test/test@XE  DIRECTORY=DATA_PUMP_DIR DUMPFILE=full.dmp FULL=y
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: