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

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

--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列都是手动配置的,复制出来执行就搞定了.

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

  • 0
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
如果你想将一个Oracle表从一个表空间移动到另一个表空间,可以使用以下步骤: 1. 创建表空间 首先,你需要创建一个表空间,使用以下语法: ``` CREATE TABLESPACE new_table_space DATAFILE '/path/to/datafile.dbf' SIZE 100M; ``` 在这里,`new_table_space` 是表空间的名称,`/path/to/datafile.dbf` 是表空间数据文件的路径和名称,`SIZE` 是数据文件的大小。 2. 导出表 接下来,你需要使用 `expdp` 命令导出表数据和元数据: ``` expdp username/password@database_name tables=table_name directory=directory_name dumpfile=dump_file_name.dmp ``` 在这里,`username` 和 `password` 是具有导出权限的有效用户的凭据,`database_name` 是数据库的名称,`table_name` 是要导出的表的名称,`directory_name` 是导出文件的目录名称,`dump_file_name.dmp` 是导出文件的名称。 3. 删除表 删除原始表: ``` DROP TABLE table_name; ``` 4. 导入表 使用 `impdp` 命令将表数据和元数据导入表空间: ``` impdp username/password@database_name directory=directory_name dumpfile=dump_file_name.dmp remap_tablespace=old_table_space:new_table_space ``` 在这里,`username` 和 `password` 是具有导入权限的有效用户的凭据,`database_name` 是数据库的名称,`directory_name` 是导出文件的目录名称,`dump_file_name.dmp` 是导出文件的名称,`old_table_space` 是原始表空间的名称,`new_table_space` 是表空间的名称。 5. 重建索引和约束 如果表有索引和约束,则需要重建这些对象以使用表空间。可以使用以下命令来检查表的索引和约束: ``` SELECT index_name FROM all_indexes WHERE table_name = 'table_name'; SELECT constraint_name FROM all_constraints WHERE table_name = 'table_name'; ``` 然后,使用以下命令为每个索引和约束重建对象: ``` ALTER INDEX index_name REBUILD TABLESPACE new_table_space; ALTER TABLE table_name ENABLE CONSTRAINT constraint_name TABLESPACE new_table_space; ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值