Oracle对数据表的表空间进行更换

本文详细介绍了在Oracle数据库中如何对单张表及用户下所有表进行表空间的更换操作。包括移动数据表的表空间、查看并重建索引的步骤,以及使用SQL语句批量操作的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、对于单张表操作更换表空间

--1、先移动数据表的表空间
ALTER TABLE 表名 MOVE TABLESPACE 表空间名;
--2、查看表上有什么索引,要加入OWNER条件,如果需要其他条件可以查所有字段 看看有没有你需要的
SELECT INDEX_NAME FROM DBA_INDEXES WHERE TABLE_NAME = '表名'  AND OWNER = '用户名' ;
--3、移动需要重建的索引
ALTER INDEX 索引名 REBUILD TABLESPACE 表空间名;

二、对于用户下所有表进行更换

操作时,建议先将数据库备份,或者导出只有建表语句的dmp文件,如下:

--导出所有表结构不要数据:
exp username/password@orcl file=e:\table.dmp owner=username rows = n

然后再导入空数据的dmp文件到新用户下,对此新用户进行操作,和上述一样,三步走,但是如果一张表一张表的弄就会很麻烦,所以这里借助一下文本编辑器和excel.

1.先查询所有表,并拼接成需要的语句,如下:

select 'ALTER TABLE '||table_name||' MOVE TABLESPACE 需要迁移的目标表空间名称;' from cat where table_type='TABLE' 

展开所有查询返回结果,复制出来,到一个新窗口中执行,此时,移动数据表的表空间操作完成

2.再查询所有表上的索引,所以此时需要获取所有表的索引名称的SQL,然后我们将所有SQL用UNION ALL 连接,如下:

select 'SELECT INDEX_NAME FROM DBA_INDEXES WHERE TABLE_NAME = '''||table_name||'''  AND OWNER = ''用户名'' union all ' from cat where table_type='TABLE' 

执行后,将所有结果复制到文本编辑器中,如下图(截取片断):

然后把最后一行中的'union all'去掉,复制到SQL窗口中,执行,再复制所有返回结果,这样就获取了所有表索引名称,然后将结果粘贴到excel中,并拼接成最后需要执行的SQL语言,如下图,其中A\B\D\E\F\G列都是手动配置的,复制出来执行就搞定了.

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值