Oracle:如何非常简单修改表的表空间?

Oracle:如何非常简单修改表的表空间?

下面来介绍两种非常简单基础的修改:
1.针对无表分区的表空间修改
2.针对有分区的修改

---------------------对于没有分区的表空间修改-----------------------
我们先查询出用户的表空间
SELECT TABLE_NAME,TABLESPACE_NAME FROM USER_TABLES;
结果如图:
Oracle:如何非常简单修改表的表空间?

比如我们看到我的库里有RPM_STM_RB_INT_DETAIL和 这个RPM_STM_RB_CR_ACCT_HIST表表空间是ETL_TS而我们想要改成USERS
我们可以先查询一下语句来汇总sql语句:
SELECT ‘ALTER TABLE ‘|| TABLE_NAME ||’ MOVE TABLESPACE TABLESPACE_NAME’ FROM USER_ALL_TABLES
也就是如图书写:
Oracle:如何非常简单修改表的表空间?
然后将表数据导出,再复制到sql窗口中运行就可以修改表空间了。

--------------------------对于有表分区的表空间修改----------------------
我们可以采取以一种非常简单的方式,不用写复杂的操作语句
也就是我们
1.将所要更改的表得表结构导出来
2.使用UE(UltraEdit)的替换将多余分区去掉,只保留一个
如:我的表是以时间分区,去除完是这样:
Oracle:如何非常简单修改表的表空间?
2.我们知道表的空间语句是这样的:
Oracle:如何非常简单修改表的表空间?
我想添加ETL_TS这个表空间,那么我们如果多个表我们就将这一部分使用UE替换到刚刚的语句当中
3.最后就是将一开始数据库中的表删除,然后导入我们修改后的语句。这样表空间就修改了