oracle10g 释放表空间

我们都知道数据表的庞大导而致其查询速度的降低是水到渠成的,所以我们只有将相关的数据表的数据相应的移走,但是如果使用Oracle delete之后,相关的数据删除了,但是速度没有多大改善,忧闷了。

使用备份表再drop掉原表。的确可以解决问题。但是较麻烦,今天请教了一个Oracle高手,解决了问题。 由于Oracle delete操作是不释放表空间的,要想提高查询速度则必须释放表空间。

对Oracle 9i而言,释放表空间则需要重新分析表。


analyze table itemLog compute statistics; 再进行select ,感觉的确快了很多。

另一种方法:使用exp将表导出,drop 掉表,再imp回去。


在一个应用中如果数据量比较大,开始影响到页面 sql 执行效率的时候,我们通常会考虑到将历史数据搬迁到一个历史库中,以此来提高当前系统的性能,但往往有时候可以发现搬迁了以后效率并没有提升或者反而有一定的下降。



其中一个主要的原因就是我们在操作的时候通常都是用 delete 语句来删除一些历史数据,但 delete 语句是不会释放表空间占用的数据块,也就是说数据是删掉了,但位置还保留着,这块空着的表空间只能由以后再 insert 进来的时候填充。很显然这不是我们想要的效果,我们想要的就是减少表空间,提高 sql 的执行效率。



下面说下解决的办法,思路就是用 alter table XX move tablespace XX; 语句将表先移到一个空闲的表空间上再移回来,网上也有人通过查 user_tables 里面的 block 字段来观察 move 表空间前后的占用的块,那个里面只是一个统计的结果,不能作为实际考量,因为在 move tablespace 的时候所有字段的 rowid 都是重新创建的,没有数据的那些块自然也就丢掉了,再 move 回来。可以理解成类似于在其他表空间创建一个临时表,把当前的表删掉重新建回来。



还有一点要注意的就是,move 的同时既然 rowid 是重新创建的,那么该表上的索引自然也就失效了,再 move 回来以后别忘了把索引重新再建一下,要不然 sql 会报错无法执行。

最后别忘了分析下表。analyze table XX compute statistics;

ALTER TABLE table_name MOVE
truncate table tab_name;

如果整表数据都可以清除,建议首选truncate table table_name;
如果delete部分数据之后还再想整理表空间,一种方法使用导入导出重组表,另一种方法是使用create table table_name as select ...达到重组表的目的。不过第二种方法需要中转表,相对麻烦一些。

DORP表,在重新建表


一种方法先DORP掉表,在重新建此表,表空间就会释放
二种方法就是MOVE表到另外一个表空间中,然后在MOVE回来

二、清除表中的数据

truncate操作 同没有where条件的delete操作十分相似,只是把表里的信息全部删除,但是表依然存在。

例如:truncate table XX

Truncate不支持回滚,并且不能truncate一个带有外键的表,如果要删除首先要取消外键,然后再删除。

truncate table 后,有可能表空间仍没有释放,可以使用如下语句:

alter table 表名称 deallocate UNUSED KEEP 0;

注意如果不加KEEP 0的话,表空间是不会释放的。

例如:

alter table F_MINUTE_TD_NET_FHO_B7 deallocate UNUSED KEEP 0;

或者:

TRUNCATE TABLE (schema)table_name DROP(REUSE) STORAGE才能释放表空间。

例如: truncate table test1 DROP STORAGE;
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要释放Oracle 11g中的undo表空间,可以按照以下步骤操作: 1. 首先,确认当前undo表空间的使用情况,可以使用以下命令查询: SELECT tablespace_name, sum(bytes)/1024/1024 "Size (MB)", sum(maxbytes)/1024/1024 "Max Size (MB)" FROM dba_data_files WHERE tablespace_name = 'UNDOTBS1' GROUP BY tablespace_name; 其中,'UNDOTBS1'为当前使用的undo表空间名称。 2. 确认当前没有任何事务在进行中,可以使用以下命令查询: SELECT COUNT(*) FROM v$transaction; 如果返回结果为0,则表示当前没有事务在进行中。 3. 执行以下命令释放undo表空间: ALTER SYSTEM CHECKPOINT; ALTER SYSTEM SET UNDO_RETENTION=0; ALTER TABLESPACE UNDOTBS1 OFFLINE IMMEDIATE; DROP TABLESPACE UNDOTBS1 INCLUDING CONTENTS AND DATAFILES; 其中,'UNDOTBS1'为当前使用的undo表空间名称。 4. 最后,确认undo表空间已经释放,可以使用以下命令查询: SELECT tablespace_name, status FROM dba_tablespaces WHERE tablespace_name = 'UNDOTBS1'; 如果返回结果为'PENDING OFFLINE',则表示undo表空间已经成功释放。 注意:释放undo表空间可能会导致数据丢失,请谨慎操作。建议在备份数据后再进行操作。 ### 回答2: 当Oracle数据库中的Undo表空间(也称为回滚段)不再使用时,它可以被释放以节省磁盘空间。在Oracle 11g中,可以按照以下步骤来释放Undo表空间: 1. 确定未使用的Undo表空间:首先需要确定哪些Undo表空间未使用。可以通过查询v$undostat视图来获取当前的Undo表空间使用情况。该视图提供有关Undo表空间大小、使用量、可用量等等信息。 2. 切换所有事务到新Undo表空间:在释放旧的Undo表空间之前,需要将所有正在运行的事务切换到新的Undo表空间中。可以通过以下方法创建一个新的Undo表空间: CREATE UNDO TABLESPACE new_undo_ts DATAFILE '/path/to/new_undo_ts.dbf' SIZE 10G; ALTER SYSTEM SET UNDO_TABLESPACE=new_undo_ts SCOPE=SPFILE; SHUTDOWN IMMEDIATE; STARTUP; 在创建新的Undo表空间之后,需要将所有正在使用旧Undo表空间的事务切换到新的Undo表空间中。可以使用以下命令来完成: ALTER SYSTEM SET UNDO_TABLESPACE=new_undo_ts; 3. 等待Undo表空间变为闲置状态:在切换所有事务到新Undo表空间之后,需要等待旧的Undo表空间变为闲置状态。可以通过查询v$rollstat视图来检查它的状态。当状态更改为“NEEDS_COMPACT”时,就开始可以释放旧的Undo表空间了。 4. 释放Undo表空间:使用以下命令释放Undo表空间: ALTER TABLESPACE old_undo_ts OFFLINE; DROP TABLESPACE old_undo_ts INCLUDING CONTENTS AND DATAFILES; 此时,“old_undo_ts”是要释放的Undo表空间的名称。 总之,在释放Undo表空间之前,需要确保所有活动的事务切换到新的Undo表空间中,并且该Undo表空间处于“闲置”状态。释放Undo表空间应该是仔细计划和谨慎实施的过程。 ### 回答3: 当Oracle 11g释放undo表空间时,需要遵循以下步骤: 1. 确认undo表空间已经没有任何无需保留的信息。可以通过检查v$rollstat动态视图、使用SQL查询语句或运行Oracle标准性能分析工具来查看当前undo空间的使用情况。 2. 执行回滚段清理,并确保没有任何未提交的事务或会话进行操作。可以使用以下语句进行回滚段清理: ALTER SYSTEM CHECKPOINT; 3. 确定当前正在使用的回滚段及其数据文件。可以使用以下语句来查询当前正在使用的回滚段: SELECT segment_name, tablespace_name FROM dba_rollback_segs WHERE status = 'USABLE' AND tablespace_name = '&tablespace_name'; 4. 更改所有正在使用的回滚段的表空间为新的undo表空间。可以使用以下语句来更改表空间: ALTER ROLLBACK SEGMENT &segment_name ONLINE; ALTER ROLLBACK SEGMENT &segment_name STORAGE (TABLESPACE &new_tablespace); 5. 删除所有旧的undo表空间。可以使用以下语句来删除表空间: DROP TABLESPACE &old_tablespace INCLUDING CONTENTS AND DATAFILES; 需要注意的是,释放undo表空间不会发生立即效果,因为Oracle在使用undo信息时会将其添加到其内部事务表中,所以要等待所有当前执行的事务完成并更新内部事务表后,才能彻底释放undo表空间。同时,释放undo表空间也要谨慎操作,以免影响数据库的稳定性和数据完整性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值