Oracle exp/imp导入不同的表空间

Oracle exp/imp导入不同的表空间

我们在做数据库表迁移时,通常会有这种需求,在开发阶段,可能所有用户的数据都放在一个表空间中,比如users表空间,但是在生产中,我们希望将每个用户的数据分别放到不同表空间中,此时直接使用exp/imp是不具备选择表空间功能的(expdp/impdp可以),这里我们提供了一种方法来实现这种功能。

正常情况下Oracle exp/imp导入不同的表空间,我们使用exp导出,再用imp导入,它会将数据导入到原来表空间中。

这里我测试新建了一个用户,三张表t1、t2、t3imp oracle,默认表空间为users

SQL> select table_name,TABLESPACE_NAME from dba_tables where owner='TEST01';
TABLE_NAME		       TABLESPACE_NAME
------------------------------ ----------------------------------------
T1			       USERS
T2			       USERS
T3			       USERS

此时我们使用exp导出

exp system/oracle file=test01.dmp owner=test01 buffer=10240 log=test01.log

在导出文件中,里面会包含建表语句,而语句中会包含表空间信息,这里截取一部分

strings test01.dmp |grep TABLESPACE

imp oracle

CREATE TABLE "T1" ("OWNER" VARCHAR2(30) NOT NULL ENABLE, "TABLE_NAME" VARCHAR2(30) NOT NULL ENABLE, "TABLESPACE_NAME" VARCHAR2(30), "CLUSTER_NAME" VARCHAR2(30), "IOT_NAME" VARCHAR2(30), "STATU S" VARCHAR2(8), "PCT_FREE" NUMBER, "PCT_USED" NUMBER, "INI_TRANS" NUMBER, "MAX_TRANS" NUMBER, "INITIAL_EXTENT" NUMBER, "NEXT_EXTENT" NUMBER,

"MIN_EXTENTS" NUMBER, "MAX_EXTENTS" NUMBER, "PCT_INCREASE" NUMBER, "FREELISTS" NUMBER, "FREELIST_GROUPS" NUMBER, "LOGGING" VARCHAR2(3), 

"BACKED_UP" VARCHAR2(1), "NUM_ROWS" NUMBER, "BLOCKS" NUMBER, "EMPTY_BLOCKS" NUMBER, "AVG_SPACE" NUMBER, "CHAIN_CNT" NUMBER, "AVG_ROW_LEN" NUMBER, 

"AVG_SPACE_FREELIST_BLOCKS" NUMBER, "NUM_FREELIST_BLOCKS" NUMBER, "DEGREE" VARCHAR2(20), "INSTANCES" VARCHAR2(20), "CACHE" VARCHAR2(10), 

"TABLE_LOCK" VARCHAR2(8), "SAMPLE_SIZE" NUMBER, "LAST_ANALYZED" DATE, "PARTITIONED" VARCHAR2(3), "IOT_TYPE" VARCHAR2(12), "TEMPORARY" VARCHAR2(1),

 "SECONDARY" VARCHAR2(1), "NESTED" VARCHAR2(3), "BUFFER_POOL" VARCHAR2(7), "ROW_MOVEMENT" VARCHAR2(8), "GLOBAL_STATS" VARCHAR2(3), 

"USER_STATS" VARCHAR2(3), "DURATION" VARCHAR2(15), "SKIP_CORRUPT" VARCHAR2(8), "MONITORING" VARCHAR2(3), "CLUSTER_OWNER" VARCHAR2(30),

 "DEPENDENCIES" VARCHAR2(8), "COMPRESSION" VARCHAR2(8), "DROPPED" VARCHAR2(3))  PCTFREE 10 PCTUSED 40 INITRANS 1 

MAXTRANS 255 STORAGE(INITIAL 393216 NEXT 1048576 FREELISTS 1 FREELIST GROUPS 1 BUFFER_POOL DEFAULT) TABLESPACE "USERS" LOGGING NOCOMPRESS

所以此时我们做imp导入时,即使新建用户指定了默认表空间,也很会导入到原来的表空间中(除非原来默认的表空间已经被删除掉了imp oracle,否则即便换用户也不行)

此时我们提供另一种方式来更改数据表的表空间Oracle exp/imp导入不同的表空间,假设用户为,步骤如下:

1、创建用户,注意一定要加默认表空间

user by ;

2、赋予权限imp oracle,注意不要赋予dba权限,如果实在需要可以导入后再赋权,当然导入操作可以用来做

GRANT TO ;

GRANT TO ;

GRANT TO ;

imp oracle

3、收回用户无限制表空间权限

from ;

4、将原来表空间的权限收回

alter user quota 0 on USERS;

5、赋予新表空间权限

alter user quota on ;

需要注意的是,假如users表空间可以删除,则可以直接导入到新的默认表空间中

此时我们直接导入,发现表全部在新的默认空间中

imp / file=.dmp = = =10240 =y log=.log

TABLE_NAME		       TABLESPACE_NAME
------------------------------ ------------------------------------------------------------------------------------------
T1			       TEST01
T2			       TEST01
T3			       TEST01

公告:
1. 本站所有资源来源于用户上传和网络,如有侵权请联系站长!
2. 分享目的仅供大家学习和交流,您必须在下载后24小时内删除!
3. 不得使用于非法商业用途,不得违反国家法律。否则后果自负!
4. 本站提供的源码、模板、插件等等其他资源,都不包含技术服务请大家谅解!
5. 如有链接无法下载、失效或广告,请联系站长处理!
6. 本站不售卖代码,资源标价只是站长收集整理的辛苦费!如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。
7. 站长QQ号码 2205675299

资源库 - 资源分享下载网 » Oracle exp/imp导入不同的表空间

常见问题FAQ

关于资源售价和售后服务的说明?
本站所有资源的标价均为本站收集资源的辛苦费,不代表资源本身的价值。软件是高智慧高价值的商品,不可能是白菜价。本站资源标价只是赞助费用,收取的赞助费仅用来维持本站的日常运营!毕竟收集整理资料需要投入云计算资源和站长大量的精力。
代码有没有售后服务和技术支持?
由于代码的运行具有不可预见性,本站不保证代码完整可运行,不提供技术支持和售后服务。 本站原创代码都是站长自己开发的,可以有偿提供技术支持服务。 网站里标明【亲测】的代码都是站长亲测过的,其他的代码由于精力有限,没有一一测试,不能保证代码就一定能够使用,更没有技术支持服务,下载前请自行斟酌。
有没有搭建服务?
由于搭建服务比较费时费力,所以本站除了原创代码外均不提供搭建服务。本站分享代码纯属兴趣爱好,不以盈利为目的,请勿咨询有没有搭建服务,谢谢理解。
链接地址失效了怎么办?
请带上资源链接地址联系客服,工作时间内我们看到后将第一时间回复。
关于解压密码
本站资源一般都没有加密,如果发现需要解压密码的,那么就输入 hao.35dc.com 试试。

发表评论

资源库,由老程序员细心甄别、精心筛选,只为提供优质的源码资源

关于我们 联系我们