一、对于单张表操作更换表空间
--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列都是手动配置的,复制出来执行就搞定了.