Oracle如何将用户下的一个表空间的数据迁移到另一个表空间

说明

前提是我们没有dba权限,然后我们要从USERS表空间迁移到自定义表空间,以下代码命名为"DIY_TABLESPACE",将其替换为你实际的目的表空间既可。

1. 查看当前USERS表空间下的对象

复制代码
-- 查看用户下所有表所在的表空间
SELECT table_name, tablespace_name 
FROM user_tables 
WHERE tablespace_name = 'USERS';

-- 查看用户下所有索引所在的表空间  
SELECT index_name, table_name, tablespace_name
FROM user_indexes
WHERE tablespace_name = 'USERS';

-- 查看用户下所有分区表的分区所在表空间
SELECT table_name, partition_name, tablespace_name
FROM user_tab_partitions
WHERE tablespace_name = 'USERS';

-- 查看用户下所有LOB字段所在的表空间
SELECT table_name, column_name, segment_name, tablespace_name
FROM user_lobs
WHERE tablespace_name = 'USERS';

2. 迁移表到新表空间

复制代码
-- 迁移单个表
ALTER TABLE 表名 MOVE TABLESPACE DIY_TABLESPACE;

-- 批量生成迁移语句(推荐)
SELECT 'ALTER TABLE ' || table_name || ' MOVE TABLESPACE DIY_TABLESPACE;'
FROM user_tables
WHERE tablespace_name = 'USERS';

3. 迁移索引到新表空间

复制代码
-- 重建索引到新表空间
ALTER INDEX 索引名 REBUILD TABLESPACE DIY_TABLESPACE;

-- 批量生成重建索引语句(推荐)这里面会出现一些命名中带$的索引会报失败,先跳过,等执行完clob再看看应该就没有了
SELECT 'ALTER INDEX ' || index_name || ' REBUILD TABLESPACE DIY_TABLESPACE;'
FROM user_indexes
WHERE tablespace_name = 'USERS';

4. 迁移LOB字段到新表空间

复制代码
-- 迁移表的LOB字段
ALTER TABLE 表名 MOVE LOB(LOB字段名) STORE AS (TABLESPACE DIY_TABLESPACE);

-- 批量生成迁移LOB语句(推荐)
SELECT 'ALTER TABLE ' || table_name || ' MOVE LOB(' || column_name || 
       ') STORE AS (TABLESPACE DIY_TABLESPACE);'
FROM user_lobs
WHERE tablespace_name = 'USERS';

5. 迁移分区表

复制代码
-- 迁移特定分区
ALTER TABLE 表名 MOVE PARTITION 分区名 TABLESPACE DIY_TABLESPACE;

-- 迁移所有分区(推荐)
SELECT 'ALTER TABLE ' || table_name || ' MOVE PARTITION ' || partition_name || 
       ' TABLESPACE DIY_TABLESPACE;'
FROM user_tab_partitions
WHERE tablespace_name = 'USERS';

6.检查索引状态,将离线的索引上线

复制代码
-- 生成所有失效索引的重建语句
SELECT 'ALTER INDEX ' || index_name || 
       ' REBUILD TABLESPACE DIY_TABLESPACE' || 
       ' ONLINE;' AS rebuild_sql
FROM user_indexes
WHERE status = 'UNUSABLE' ;

-- 将上一步的输出结果复制出来,作为脚本执行,以下是例子。
ALTER INDEX 索引名 REBUILD TABLESPACE 表空间名 ONLINE;

上面执行完之后再检查一下索引状态是不是VALID

select status from user_indexes;

6.验证迁移结果

复制代码
-- 查询为0正常
SELECT COUNT(*) 
FROM user_segments
WHERE tablespace_name = 'USERS';
相关推荐
倒流时光三十年23 分钟前
SpringBoot 数据库同步 Elasticsearch 性能优化
数据库·spring boot·elasticsearch
码农小卡拉1 小时前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot
怣501 小时前
MySQL多表连接:全外连接、交叉连接与结果集合并详解
数据库·sql
wjhx1 小时前
QT中对蓝牙权限的申请,整理一下
java·数据库·qt
冰暮流星1 小时前
javascript之二重循环练习
开发语言·javascript·数据库
万岳科技系统开发2 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
冉冰学姐2 小时前
SSM智慧社区管理系统jby69(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·管理系统·智慧社区·ssm 框架
杨超越luckly2 小时前
HTML应用指南:利用GET请求获取中国500强企业名单,揭秘企业增长、分化与转型的新常态
前端·数据库·html·可视化·中国500强
Elastic 中国社区官方博客2 小时前
Elasticsearch:Workflows 介绍 - 9.3
大数据·数据库·人工智能·elasticsearch·ai·全文检索
仍然.2 小时前
MYSQL--- 聚合查询,分组查询和联合查询
数据库