移动表空间所使用的脚本以及语句
来源:互联网 发布:antpool矿池挖矿软件 编辑:程序博客网 时间:2024/06/05 14:10
一常规移动表空间的脚本语句
select 'alter table ' || a.owner || '.' || TABLE_NAME ||
' move tablespace TS_DISA_DATA;'
from dba_tables a
where a.tablespace_name = 'TS_QBJCK'
and owner='GAQJK';
select *
from dba_tables a
where a.tablespace_name = 'TS_QBJCK' and ower;
select 'alter table' || table_name || 'move lob(' || index_name ||
') store as (tablespace tbs_name);'
from dba_indexes
where wner = '%***%'
and index_name like '%***%';
select 'alter index ' || c.owner || '.' || index_name || ' rebuild tablespace TS_DRM_META;' index_name
from dba_indexes c
where c.status='UNUSABLE';
二、移动分区表和分区索引
移动分区表的表空间
1) 非组合分区表
alter table RPT_F_STATION_DP move PARTITION SYS3601 tablespace ZHKDATA;
2) 组合分区表:
(1)先移动子分区到另一个表空间 :
alter table RPT_F_CABECF move SUBPARTITION SYS_SUB2 tablespace ZHKDATA;
(2)subpartition已经move走了,就剩下subpartition的father了,那就不需要move了,改一下分区的属性就可以了。
ALTER TABLE T_BS_RK_CZRK MODIFY DEFAULT ATTRIBUTES FOR PARTITION PARTITION_3601 TABLESPACE ZHKDATA;
注:
如直接move含有子分区的分区将发生如下错误
ORA-14257: cannot move partition other than a Range or Hash partition
移动分区表上index的表空间
1)非分区index
ALTER INDEX PK_RPT_F_NOFINISH_WORKSHEET REBUILD TABLESPACE ZHKDATA;
2)无子分区的index
ALTER INDEX IDX_RPT_F_STATION_DP_1 REBUILD PARTITION SYS_WB01 TABLESPACE ZHKDATA;
3)子分区index
ALTER INDEX IDX_RPT_F_CABECF_1 REBUILD SUBPARTITION SYS_WB012 TABLESPACE ZHKDATA;
四、自动生成需要的脚本
SELECT 'alter table '
|| table_name
|| ' move PARTITION '
|| partition_name
|| ' tablespace ZHKDATA;'
FROM USER_TAB_PARTITIONS
WHERE SUBPARTITION_COUNT = 0 AND tablespace_name = 'TS_ZHKJCK'; -- 非组合分区表
SELECT 'alter table '
|| table_name
|| ' move subPARTITION '
|| SUBPARTITION_NAME
|| ' tablespace ZHKDATA;'
FROM USER_TAB_SUBPARTITIONS
WHERE SUBPARTITION_COUNT > 0 AND tablespace_name = 'TS_ZHKJCK'; --移动子分区
SELECT 'ALTER TABLE '
|| table_name
|| ' MODIFY DEFAULT ATTRIBUTES FOR PARTITION '
|| partition_name
|| ' TABLESPACE ZHKDATA;'
FROM USER_TAB_PARTITIONS
WHERE SUBPARTITION_COUNT > 0 AND tablespace_name = 'TS_ZHKJCK';--修改母分区属性
SELECT 'ALTER INDEX ' || INDEX_NAME || ' REBUILD TABLESPACE ZHKDATA;'
FROM USER_INDEXES
WHERE tablespace_name='TS_ZHKJCK';
SELECT 'ALTER INDEX '
|| index_name
|| ' REBUILD PARTITION '
|| PARTITION_NAME
|| ' TABLESPACE ZHKDATA; '
FROM USER_IND_PARTITIONS
where SUBPARTITION_COUNT = 0
and tablespace_name='TS_ZHKJCK'; -- 无子分区的index
SELECT 'ALTER INDEX '
|| index_name
|| ' REBUILD SUBPARTITION '
|| SUBPARTITION_NAME
|| ' TABLESPACE ZHKDATA; '
FROM USER_IND_SUBPARTITIONS
where tablespace_name='TS_ZHKJCK'; --子分区index
无、特殊的表
使用上面语句对表做空间迁移时,只能移动非lob字段以外的数据,如果要同时移动lob字段数据,必需改用下面的语句才行:
alter table tb_name move tablespace tbs_name lob (col_lob1,col_lob2) store as (tablesapce tbs_name);
select 'alter table ' || a.owner || '.' || TABLE_NAME ||
' move tablespace TS_DISA_DATA;'
from dba_tables a
where a.tablespace_name = 'TS_QBJCK'
and owner='GAQJK';
select *
from dba_tables a
where a.tablespace_name = 'TS_QBJCK' and ower;
select 'alter table' || table_name || 'move lob(' || index_name ||
') store as (tablespace tbs_name);'
from dba_indexes
where wner = '%***%'
and index_name like '%***%';
select 'alter index ' || c.owner || '.' || index_name || ' rebuild tablespace TS_DRM_META;' index_name
from dba_indexes c
where c.status='UNUSABLE';
二、移动分区表和分区索引
移动分区表的表空间
1) 非组合分区表
alter table RPT_F_STATION_DP move PARTITION SYS3601 tablespace ZHKDATA;
2) 组合分区表:
(1)先移动子分区到另一个表空间 :
alter table RPT_F_CABECF move SUBPARTITION SYS_SUB2 tablespace ZHKDATA;
(2)subpartition已经move走了,就剩下subpartition的father了,那就不需要move了,改一下分区的属性就可以了。
ALTER TABLE T_BS_RK_CZRK MODIFY DEFAULT ATTRIBUTES FOR PARTITION PARTITION_3601 TABLESPACE ZHKDATA;
注:
如直接move含有子分区的分区将发生如下错误
ORA-14257: cannot move partition other than a Range or Hash partition
移动分区表上index的表空间
1)非分区index
ALTER INDEX PK_RPT_F_NOFINISH_WORKSHEET REBUILD TABLESPACE ZHKDATA;
2)无子分区的index
ALTER INDEX IDX_RPT_F_STATION_DP_1 REBUILD PARTITION SYS_WB01 TABLESPACE ZHKDATA;
3)子分区index
ALTER INDEX IDX_RPT_F_CABECF_1 REBUILD SUBPARTITION SYS_WB012 TABLESPACE ZHKDATA;
四、自动生成需要的脚本
SELECT 'alter table '
|| table_name
|| ' move PARTITION '
|| partition_name
|| ' tablespace ZHKDATA;'
FROM USER_TAB_PARTITIONS
WHERE SUBPARTITION_COUNT = 0 AND tablespace_name = 'TS_ZHKJCK'; -- 非组合分区表
SELECT 'alter table '
|| table_name
|| ' move subPARTITION '
|| SUBPARTITION_NAME
|| ' tablespace ZHKDATA;'
FROM USER_TAB_SUBPARTITIONS
WHERE SUBPARTITION_COUNT > 0 AND tablespace_name = 'TS_ZHKJCK'; --移动子分区
SELECT 'ALTER TABLE '
|| table_name
|| ' MODIFY DEFAULT ATTRIBUTES FOR PARTITION '
|| partition_name
|| ' TABLESPACE ZHKDATA;'
FROM USER_TAB_PARTITIONS
WHERE SUBPARTITION_COUNT > 0 AND tablespace_name = 'TS_ZHKJCK';--修改母分区属性
SELECT 'ALTER INDEX ' || INDEX_NAME || ' REBUILD TABLESPACE ZHKDATA;'
FROM USER_INDEXES
WHERE tablespace_name='TS_ZHKJCK';
SELECT 'ALTER INDEX '
|| index_name
|| ' REBUILD PARTITION '
|| PARTITION_NAME
|| ' TABLESPACE ZHKDATA; '
FROM USER_IND_PARTITIONS
where SUBPARTITION_COUNT = 0
and tablespace_name='TS_ZHKJCK'; -- 无子分区的index
SELECT 'ALTER INDEX '
|| index_name
|| ' REBUILD SUBPARTITION '
|| SUBPARTITION_NAME
|| ' TABLESPACE ZHKDATA; '
FROM USER_IND_SUBPARTITIONS
where tablespace_name='TS_ZHKJCK'; --子分区index
无、特殊的表
使用上面语句对表做空间迁移时,只能移动非lob字段以外的数据,如果要同时移动lob字段数据,必需改用下面的语句才行:
alter table tb_name move tablespace tbs_name lob (col_lob1,col_lob2) store as (tablesapce tbs_name);
0 0
- 移动表空间所使用的脚本以及语句
- Scripts:查看表空间的语句脚本
- 使用 SELECT 查询语句拼接 迁移表至其他表空间的 SQL 脚本 语句
- 把oracle表空间所对应的数据文件移动
- 脚本之查看当前会话所执行的语句以及会话相关信息
- oracle查询表空间大小以及每个表所占空间的大小
- 查表空间使用情况的语句
- Oracle之表空间的类别、体会以及脚本
- 使用Spring AOP与Annotation所需的jar包以及命名空间操作
- Oracle查看用户默认表空间使用情以及手动扩展表空间sql语句
- 数据库空间以及表空间的使用情况
- 移动表空间的数据文件
- 检查临时表空间的使用情况--脚本
- 自动监控oracle 表空间使用量的脚本
- 【脚本分享】表空间每天的使用情况
- oracle表空间使用状态以及sga、pga各个参数查询语句
- 【空间管理】检测表空间空间的使用情况以及碎片
- Oracle DBA--查看表空间的使用情况SQL语句
- Java反射机制的学习(转)
- 十年学会程序设计
- fatal error LNK1123: 转换到 COFF 期间失败: 文件无效或损坏
- SWFUpload flash文件上传使用集锦
- Jtag的各种引脚定义
- 移动表空间所使用的脚本以及语句
- 自动生成Linux下Makefile全攻略(下)
- [学习记录]C++进程间共享内存
- 从头到尾彻底解析哈希表算法
- 散列表(哈希表)
- iOS多线程编程之NSOperation和NSOperationQueue的使用
- scala扩展性
- 机器学习中的超平面
- kali下练习php