- 浏览: 164818 次
- 性别:
- 来自: 南京
文章分类
- 全部博客 (327)
- JAVA (130)
- 工作笔记 (49)
- SQLSERVER (5)
- ORACLE (28)
- nginx (1)
- Unix C (16)
- 系统 (19)
- 网络技术 (17)
- WEB前端 (22)
- Eclipse (2)
- Tomcat (1)
- spring (7)
- MYSQL (12)
- Maven (6)
- JETTY (2)
- 设计 (2)
- 开源项目 (7)
- asterisk (0)
- C++ (2)
- WINDOWS (2)
- SCALA (0)
- 协议 (1)
- Netty (1)
- SHELL (1)
- mybaits (4)
- 并发 (2)
- 架构 (2)
- TCP/IP (8)
- 虚拟化 (3)
- 不要再说java慢 (0)
- mac (2)
- mysql乱码完美解决 (1)
最新评论
转自 http://blog.sina.com.cn/s/blog_81095bbb01014d63.html
背景说明:根据数据库最佳实践应该把应用数据的表与索引放在不同的表空间,现在需要用exp/imp转移用户,同时将之前错误地放入数据库表空间的索引挪到独立的索引表空间。因为数据量较大,exp/imp已经占用大量停机时间,所以不能通过rebuild来修改表空间。我的想法是通过利用impdp的特性(remap_tablespace)来实现,分阶段导入数据,把索引导入独立进行并remap tablespace。实践过程中发现一个问题,主键索引是随表导入的,不能通过remap来修改,所以才有预创建空表来更改主键索引的表空间,再导入数据。
下面是实验过程:
【实验准备】
建实验用的表空间:DAT/IDX
$ sqlplus "/as sysdba"
数据表空间DAT:SQL> Create tablespace DAT datafile '/oracle/oradata_10g/test/dat01.dbf' size 1m;
索引表空间IDX:SQL> Create tablespace IDX datafile '/oracle/oradata_10g/test/idx01.dbf' size 1m;
建实验用户:test/test,默认表空间:DAT
SQL> create user test identified by "test" default tablespace DAT;
SQL> grant dba to test;
建实验数据表:
sqlplus test/test
SQL> create table users(id number(8,0) primary key, name varchar(10) not null);
SQL> create index idx_users_name on users(name);
SQL> insert into users values(1,'A');
SQL> insert into users values(2,'B');
SQL> commit;
查看索引:
SQL> select owner,index_name,tablespace_name from dba_indexes where owner='TEST';
OWNER INDEX_NAME TABLESPACE_NAME
------------------------------ ------------------------------ ----------------
TEST IDX_USERS_NAME DAT
TEST SYS_C0018263 DAT
可见表users有两个索引,一个主键索引,一个普通索引idx_users_name.都默认位于DAT表空间内。
【导出数据】
SQL> create directory DUMP_DIR1 as '/oracle/oradata_10g/test/dump';
$ cd /oracle/oradata_10g/test/dump
$ expdp schemas=test dumpfile=test.dmp directory=DUMP_DIR1 logfile=exp_test.log
用户:/ as sysdba
【导入数据】
先清空旧数据:
SQL> drop table users;
确认:SQL> select * from dba_objects where owner='TEST'
重建表,修改了主键的表空间定义:
查看创建表的DDL语句:
select dbms_metadata.get_ddl('TABLE','USERS','TEST') from dual;
创建表:create table users(id number(8,0) primary key using index tablespace IDX, name varchar(10) not null);
主键索引表空间已修改,如上红色字体所示。
导入表(不含索引):
cd /oracle/oradata_10g/test/dump
impdp schemas=test dumpfile=test.dmp directory=DUMP_DIR1 logfile=imp_test_table.log exclude=INDEX,INDEX_STATISTICS TABLE_EXISTS_ACTION=APPEND
因为表已创建,所以只能用APPEND模式来导入数据,这是必需的参数,否则默认会忽略该表的数据导入。
导入索引(仅索引,不含表):
impdp schemas=test include=INDEX,INDEX_STATISTICS dumpfile=test.dmp directory=DUMP_DIR1 logfile=imp_test_index.log REMAP_TABLESPACE=DAT:IDX
remap修改了非主键索引的表空间。
查看索引:
select * from dba_indexes where owner='TEST'
可以看到索引全部表迁移到IDX表空间,而数据表仍然在DAT表空间。
【清除实验数据】
drop user test cascade;
drop tablespace DAT;
drop tablespace IDX;
【补充说明】
如果数据量较小,或者不用计较太长的停机时间,那么可先用常规方法导入数据,然后用下面语句重建索引并修改表空间即可:
alter index IDX_USERS_NAME rebuild tablespace IDX;
alter index SYS_C0018263 rebuild tablespace IDX;
背景说明:根据数据库最佳实践应该把应用数据的表与索引放在不同的表空间,现在需要用exp/imp转移用户,同时将之前错误地放入数据库表空间的索引挪到独立的索引表空间。因为数据量较大,exp/imp已经占用大量停机时间,所以不能通过rebuild来修改表空间。我的想法是通过利用impdp的特性(remap_tablespace)来实现,分阶段导入数据,把索引导入独立进行并remap tablespace。实践过程中发现一个问题,主键索引是随表导入的,不能通过remap来修改,所以才有预创建空表来更改主键索引的表空间,再导入数据。
下面是实验过程:
【实验准备】
建实验用的表空间:DAT/IDX
$ sqlplus "/as sysdba"
数据表空间DAT:SQL> Create tablespace DAT datafile '/oracle/oradata_10g/test/dat01.dbf' size 1m;
索引表空间IDX:SQL> Create tablespace IDX datafile '/oracle/oradata_10g/test/idx01.dbf' size 1m;
建实验用户:test/test,默认表空间:DAT
SQL> create user test identified by "test" default tablespace DAT;
SQL> grant dba to test;
建实验数据表:
sqlplus test/test
SQL> create table users(id number(8,0) primary key, name varchar(10) not null);
SQL> create index idx_users_name on users(name);
SQL> insert into users values(1,'A');
SQL> insert into users values(2,'B');
SQL> commit;
查看索引:
SQL> select owner,index_name,tablespace_name from dba_indexes where owner='TEST';
OWNER INDEX_NAME TABLESPACE_NAME
------------------------------ ------------------------------ ----------------
TEST IDX_USERS_NAME DAT
TEST SYS_C0018263 DAT
可见表users有两个索引,一个主键索引,一个普通索引idx_users_name.都默认位于DAT表空间内。
【导出数据】
SQL> create directory DUMP_DIR1 as '/oracle/oradata_10g/test/dump';
$ cd /oracle/oradata_10g/test/dump
$ expdp schemas=test dumpfile=test.dmp directory=DUMP_DIR1 logfile=exp_test.log
用户:/ as sysdba
【导入数据】
先清空旧数据:
SQL> drop table users;
确认:SQL> select * from dba_objects where owner='TEST'
重建表,修改了主键的表空间定义:
查看创建表的DDL语句:
select dbms_metadata.get_ddl('TABLE','USERS','TEST') from dual;
创建表:create table users(id number(8,0) primary key using index tablespace IDX, name varchar(10) not null);
主键索引表空间已修改,如上红色字体所示。
导入表(不含索引):
cd /oracle/oradata_10g/test/dump
impdp schemas=test dumpfile=test.dmp directory=DUMP_DIR1 logfile=imp_test_table.log exclude=INDEX,INDEX_STATISTICS TABLE_EXISTS_ACTION=APPEND
因为表已创建,所以只能用APPEND模式来导入数据,这是必需的参数,否则默认会忽略该表的数据导入。
导入索引(仅索引,不含表):
impdp schemas=test include=INDEX,INDEX_STATISTICS dumpfile=test.dmp directory=DUMP_DIR1 logfile=imp_test_index.log REMAP_TABLESPACE=DAT:IDX
remap修改了非主键索引的表空间。
查看索引:
select * from dba_indexes where owner='TEST'
可以看到索引全部表迁移到IDX表空间,而数据表仍然在DAT表空间。
【清除实验数据】
drop user test cascade;
drop tablespace DAT;
drop tablespace IDX;
【补充说明】
如果数据量较小,或者不用计较太长的停机时间,那么可先用常规方法导入数据,然后用下面语句重建索引并修改表空间即可:
alter index IDX_USERS_NAME rebuild tablespace IDX;
alter index SYS_C0018263 rebuild tablespace IDX;
发表评论
-
oracle 分页
2015-09-17 20:31 552SELECT * FROM (SELECT A.*, R ... -
批量造数据
2015-08-01 17:19 0CREATE OR REPLACE PROCEDURE ES_ ... -
11g归档
2015-03-23 22:31 404数据库归档 http://blog.sina.com.cn/s ... -
数据库压力测试
2015-03-21 22:04 545http://www.cnblogs.com/rootq/ar ... -
明天试试这个视图
2015-03-19 21:12 367V$SEGMENT_STATISTICS 用法 -
Oracle建立序列
2015-03-16 12:02 555create sequence hibernate_seq ... -
netstat 的使用
2015-03-09 16:48 487netstat -ltpe 查看当前活跃的连接 http:/ ... -
关于位图索引的帖子
2015-03-09 12:33 457http://www.itpub.net/thread-183 ... -
【转】Oracle 使用lock_sga和pre_page_sga参数保证SGA常驻物理内存
2015-03-09 11:33 510http://blog.csdn.net/laoshangxy ... -
视图的用法
2015-02-27 21:30 387关于视图的概念 http://blog.sina.com.cn ... -
oracle调优方法
2015-02-25 11:07 411一上午 10:36:13 这个东西需要看报表是吧? 大 ... -
ORACLE 伪列
2014-08-05 16:20 317多个不同的表要UNION在一起得出结果,为了统一输出结果,要用 ... -
表空间 用户 表
2014-04-24 16:48 3671. 创建一个表空间 create tablespace L ... -
ORACLE 分区
2013-10-26 17:52 588------------------------------- ... -
工作中用的两条查询语句,LEFT JOIN多张表的
2013-09-13 16:57 905----4G手机 left join 三张表 select a ... -
Split
2013-07-25 20:59 750CREATE OR REPLACE TYPE type_spl ... -
蒙昭良的博客地址.
2013-06-21 15:01 891http://space.itpub.net/12778571 ... -
Oracle 数据库用户管理
2013-06-21 14:57 401Oracle 数据库用户管理 Oracle 权限设置 一、权限 ... -
ORACLE中的五种约束
2013-06-21 13:48 831CREATE TABLE TABLENAMEEXAMLE( ... -
查看Oracle数据库表空间(转)
2013-06-21 13:25 449/* *时间:2009-04-01 *环境:AIX5.3 ...
相关推荐
### Oracle 多个表空间合并成一个表空间详解 #### 背景介绍 在进行数据库维护时,可能会遇到需要将多个表空间合并为一个的情况。这种情况通常发生在新项目的开发过程中,尤其是当新项目需要引用来自其他表空间的...
然后,在目标环境使用IMPDP导入数据,同时可能需要进行表空间映射。例如: ``` impdp 用户名/密码 directory=DATA_PUMP_DIR dumpfile=data.dmp logfile=impdp.log remap_tablespace=源表空间:目标表空间 ``` 2....
"ORACLE导入数据文件到指定的表空间"这个主题涉及了Oracle数据库的导入工具(IMP)、数据泵(IMPDP)以及如何规划和管理表空间。 首先,我们需要了解Oracle的导入工具IMP。IMP是Oracle Data Pump Import的简称,它...
本文将围绕"Oracle命令大全及关于Oracle 1000问"的主题,深入讲解日志管理、表空间管理、表操作和索引管理等关键知识点。 首先,日志管理在Oracle数据库中至关重要,因为它是数据恢复的基础。主要涉及Redo Logs和...
临时表空间主要用于存储临时数据,如排序操作、索引创建等过程中产生的临时数据。如果系统中已经有足够的临时表空间,那么新创建的临时表空间可能并不是必需的。创建临时表空间的语法如下: ```sql CREATE ...
表空间是Oracle数据库中逻辑存储结构的基本单位,它由一个或多个数据文件组成,用于存放数据库对象,如表、索引等。表空间的创建、扩展和删除直接影响到数据库的性能和存储管理。 **备份Oracle表空间** 1. **完整...
这种文件包含了表定义、索引、约束条件等元数据以及表中的数据,通常通过Oracle的`EXPDP`和`IMPDP`命令来创建或导入。 #### 二、Oracle DMP 文件导出过程 在开始导出DMP文件之前,首先需要确保Oracle环境中已安装并...
表空间是Oracle数据库中存储数据的基本单元,它将物理磁盘空间与逻辑数据存储结构关联起来。临时表空间则是用于存储临时数据,比如排序或连接操作产生的中间结果。本文档将深入探讨如何在Oracle中创建临时表空间,并...
本文将深入探讨Oracle表空间的概念、作用、类型以及如何进行管理,结合给定的压缩包文件“把atf_ygj的数据移动到ygj_data表空间中”,我们将讲解如何进行表空间的数据迁移。 首先,表空间是由一个或多个数据文件...
表空间是用来组织和管理数据库的数据和索引的逻辑容器。当创建新的数据库对象时,必须指定其所在的表空间。 现在,我们来详细说明创建“huike”用户和表空间的步骤: 1. **创建表空间**: 首先,我们需要创建一个...
它可以导入整个数据库、特定的方案、表空间或单个表。impdp 还支持网络模式,允许跨数据库的数据导入。 **2. 使用 impdp 导入数据的步骤** - **创建目录对象**:首先,你需要在数据库中创建一个目录对象来指定转储...
3. **用expdp实用程序导出元数据**:使用数据泵导出工具导出表空间的元数据,包括表定义、索引、约束等信息。 4. **转换数据文件以匹配Endian格式**(若平台格式一致则跳过):如果源目标平台的字节序不同,需要使用...
在Oracle数据库中,表空间是存储数据的基本单位,它由一个或多个数据文件组成,用于存储用户的数据、索引和其他数据库对象。当需要迁移数据、调整存储策略或解决空间不足问题时,快速且专业地转移表空间变得尤为重要...
Oracle传输表空间是一种高效的数据迁移方法,允许用户在不同的Oracle数据库之间移动表空间,而无需进行完整数据库的备份和恢复。以下将详细解释如何进行Oracle传输表空间的操作,并阐述其中的关键知识点。 首先,...
本文将深入探讨Oracle中常用的SQL语句以及与数据库表空间相关的维护知识。 首先,让我们了解如何在Oracle中创建表空间。表空间是Oracle数据库中存储数据的逻辑单位,它由一个或多个数据文件组成。创建表空间的SQL...
在Oracle数据库管理中,表空间(Tablespace)是存储数据对象(如表、索引、视图等)的逻辑单位。表空间的概念使得数据库管理员能够有效地管理存储资源,分配和调整磁盘空间。以下是关于Oracle中创建表空间、创建用户...
Oracle 表空间是数据库管理的重要组成部分,用于存储数据库对象如表、索引等。以下是关于Oracle表空间操作的详解: 1. **创建表空间** 创建表空间的语法如下: ```sql CREATE TABLESPACE DATAFILE '<filepath>...
在Oracle中,创建表空间的目的是为了组织和管理数据库中的对象,比如表、索引等。创建表空间的SQL语句如下: ```sql create tablespace 表间名 datafile '数据文件名' size 表空间大小; ``` 例如,创建名为`news...
Oracle数据库管理是数据库管理员(DBA)日常工作中不可或缺的一部分,涉及到用户、角色、表空间以及数据的导入导出。在Oracle环境中,理解如何创建、删除这些元素以及如何通过命令行进行操作至关重要。以下是对这些...
2.3 复制数据文件的方法:在特定场景下,数据泵可以直接复制数据文件,这种方式适用于整个数据库或表空间的迁移。 2.4 Network_Link的方式:通过网络链接,数据泵可以在多个数据库之间进行数据传输,实现跨数据库的...