Oracle exp/imp导入不同的表空间
来源:互联网 发布:草履虫软件下载 编辑:程序博客网 时间:2024/06/14 06:25
我们在做Oracle数据库表迁移时,通常会有这种需求,在开发阶段,可能所有用户的数据都放在一个表空间中,比如users表空间,但是在生产中,我们希望将每个用户的数据分别放到不同表空间中,此时直接使用exp/imp是不具备选择表空间功能的(expdp/impdp可以),这里我们提供了一种方法来实现这种功能。
正常情况下,我们使用exp导出,再用imp导入,它会将数据导入到原来表空间中。
这里我测试新建了一个用户test01,三张表t1、t2、t3,默认表空间为users
SQL> select table_name,TABLESPACE_NAME from dba_tables where owner='TEST01';TABLE_NAME TABLESPACE_NAME------------------------------ ----------------------------------------T1 USERST2 USERST3 USERS
此时我们使用exp导出
exp system/oracle file=test01.dmp owner=test01 buffer=10240 log=test01.log在导出文件中,里面会包含建表语句,而语句中会包含表空间信息,这里截取一部分
strings test01.dmp |grep TABLESPACECREATE 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), "STATUS" 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导入时,即使新建用户指定了默认表空间,也很会导入到原来的表空间中(除非原来默认的表空间已经被删除掉了,否则即便换用户也不行)
此时我们提供另一种方式来更改数据表的表空间,假设用户为test01,步骤如下:
1、创建用户,注意一定要加默认表空间
create user test01 identified by test01 default tablespace test01;
2、赋予权限,注意不要赋予dba权限,如果实在需要可以导入后再赋权,当然导入操作可以用system来做
GRANT CONNECT TO test01;
GRANT IMP_FULL_DATABASE TO test01;
GRANT RESOURCE TO test01;
3、收回用户test01无限制表空间权限
revoke unlimited tablespace from test01;
4、将原来表空间的权限收回
alter user test01 quota 0 on USERS;
5、赋予新表空间权限
alter user test01 quota unlimited on test01;
需要注意的是,假如users表空间可以删除,则可以直接导入到新的默认表空间test01中
此时我们直接导入,发现表全部在新的默认空间中
imp system/oracle file=test01.dmp fromuser=test01 touser=test01 buffer=10240 commit=y log=imptest01.log
TABLE_NAME TABLESPACE_NAME------------------------------ ------------------------------------------------------------------------------------------T1 TEST01T2 TEST01T3 TEST01
- Oracle exp/imp导入不同的表空间
- 把数据导入不同的表空间(exp,imp)
- 把数据导入不同的表空间(exp,imp)
- exp-imp实现oracle不同表空间的迁移
- exp-imp实现oracle不同表空间的迁移
- exp-imp实现oracle不同表空间的迁移
- 解决oracle exp/imp导入表空间过大问题
- Oracle中exp,imp的TableSpace表空间问题
- Oracle中exp,imp的TableSpace表空间问题
- imp exp oracle 数据的导入导出
- oracle导入/导出imp,exp的应用
- oracle的导入导出imp/exp
- 使用exp/imp传输表空间(Oracle)
- Oracle 复制表空间 (imp/exp)
- oracle exp imp 命令 转换表空间
- 关于在IMP时指定表空间的心得:将EXP出来的数据IMP进不同的表空间
- oracle用exp\imp导出导入,及创建表空间与用户
- oracle imp exp 导入导出
- Vue2+VueRouter2+Webpack+Axios 构建项目实战2017重制版(五)配置 Axios api 接口调用文件
- 初学Nginx(一)监听两个端口,实现转发
- Median [二分]
- 考研数据结构复习之线性表
- 常见的几种RuntimeException
- Oracle exp/imp导入不同的表空间
- java 数据结构与排序
- .net多线程学习
- Socket编程中select函数用法详解(转)
- charles(windows64位) 抓包工具安装及详解
- 柔性数组
- 【Java】Reactor模式
- SpringMVC 图片上传
- GX WORKS2 快捷键