阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Oracle deallocate unused释放高水位空间

464次阅读
没有评论

共计 7544 个字符,预计需要花费 19 分钟才能阅读完成。

deallocate unused : 仅适用于释放 HWM 高水位以上的空间,而无法释放高水位以下的空间;比如对表预分配的空间

使用说明和方法,官方文档有说明,如下:

Use the deallocate_unused_clause to explicitly deallocate unused space at the end of

a database object segment and make the space available for other segments in the

tablespace.

You can deallocate unused space using the following statements:

■ ALTER CLUSTER (see ALTER CLUSTER on page 10-5)

■ ALTER INDEX: to deallocate unused space from the index, an index partition, or an

index subpartition (see ALTER INDEX on page 10-78)

■ ALTER MATERIALIZED VIEW: to deallocate unused space from the overflow segment

of an index-organized materialized view (see ALTER MATERIALIZED VIEW on

page 11-3)

■ ALTER TABLE: to deallocate unused space from the table, a table partition, a table

subpartition, the mapping table of an index-organized table, the overflow segment

of an index-organized table, or a LOB storage segment (see ALTER TABLE on

page 12-2)

一、测试环境:

 Oracle11.2.0.4

 使用 admin 用户在 test 表空间新建一张测试分区表,并提前对子分区预分配一些空间,然后插入少量的数据,最后使用:alter  table …..deallocate unused; 来释放未使用的空间

二、开始测试

①:查看测试环境表空间使用情况:

SQL> set linesize 2500
SQL> set pagesize 300
SQL> select a.tablespace_name “ 表空间名称 ”,100 – round((nvl(b.bytes_free, 0) / a.bytes_alloc) * 100, 2) “ 占用率 (%)”,round(a.bytes_alloc / 1024 / 1024, 2) “ 容量 (M)”,round(nvl(b.bytes_free, 0) / 1024 / 1024, 2) “ 空闲 (M)”,round((a.bytes_alloc – nvl(b.bytes_free, 0)) / 1024 / 1024, 2) “ 使用 (M)”,to_char(sysdate, ‘yyyy-mm-dd hh24:mi:ss’) “ 采样时间 ” from (select f.tablespace_name,sum(f.bytes) bytes_alloc,sum(decode(f.autoextensible, ‘YES’, f.maxbytes, ‘NO’, f.bytes)) maxbytes from dba_data_files f group by tablespace_name) a,(select f.tablespace_name, sum(f.bytes) bytes_free from dba_free_space f group by tablespace_name) b where a.tablespace_name = b.tablespace_name order by 2 desc;
???????????????                ?????????(%)  ??????(M)  ??????(M)  ??????(M) ????????????
—————————— ———— ———- ———- ———- ——————-
SYSAUX                                94.41        510      28.5      481.5 2017-08-07 17:01:20
SYSTEM                                93.24        800      54.06    745.94 2017-08-07 17:01:20
USERS                                26.25          5      3.69      1.31 2017-08-07 17:01:20
UNDOTBS1                              17.97        470    385.56      84.44 2017-08-07 17:01:20
TEST                                    .05      20480      20470        10 2017-08-07 17:01:20

SQL> show user
USER is “ADMIN”    —- 测试用的用户

②:创建测试分区表:test_emp 

SQL> create table test_emp (TMP_UPSTATE_CASEKEY char(14),TMP_NUM_STATUS_ID number(38),updated_date date)
  2  partition by range(TMP_NUM_STATUS_ID)
  3          (partition pt_1 values less than(1000000) ) nologging;
Table created.

③:给 pt_1 分区表预分配 10G 的空间:

SQL> alter table test_EMP  modify PARTITION pt_1 ALLOCATE EXTENT (size 10240m);
Table altered.

④:收集该分区表的统计信息,并查看该表的 block 块占用情况

SQL>  exec dbms_stats.gather_table_stats(ownname =>’ADMIN’,tabname =>’TEST_EMP’,cascade=>TRUE);
PL/SQL procedure successfully completed.
SQL>  select B.SEGMENT_NAME, B.blocks,B.blocks * 8096 / 1024 / 1024, A.BLOCKS,A.blocks * 8096 / 1024 / 1024, A.EMPTY_BLOCKS from user_tables a, USER_SEGMENTS B WHERE TABLE_NAME = ‘TEST_EMP’ AND A.TABLE_NAME = B.SEGMENT_NAME;
SEGMENT_NAME                                                                          BLOCKS B.BLOCKS*8096/1024/1024    BLOCKS A.BLOCKS*8096/1024/1024 EMPTY_BLOCKS
——————————————————————————— ———- ———————– ———- ———————– ————
TEST_EMP                                                                            1315840              10159.5313          0                      0            0
SQL> SELECT segment_name, SUM(bytes) / 1024 / 1024 Mbytes  FROM dba_segments WHERE    PARTITION_NAME = ‘PT_1’ GROUP BY segment_name;
SEGMENT_NAME                                                                          MBYTES
——————————————————————————— ———-
TEST_EMP                                                                              10288
BIN$VibHVCPfDL/gU8gCqMDDfw==$0                                                            8

— 从上面可以看出,test_emp 分区表的大小是 10G,而占用的 blocks 有 1315840 个;

⑤:向分区表插入一些数据,并查看该表的大小

SQL> create or replace procedure proc_casekey_upstate
  2  as
  3    casekey char(14);
  4  begin
  5    for i in 1..10000 loop
  6      casekey := ‘TMP’||lpad(i,7,0); 
  7      insert into test_emp values(casekey, 1, sysdate);
  8    end loop;
  9    commit;
 10  end;
 11  /
Procedure created.
SQL> exec proc_casekey_upstate;    — 执行存储过程插入数据
PL/SQL procedure successfully completed.
SQL> exec dbms_stats.gather_table_stats(ownname =>’ADMIN’,tabname =>’TEST_EMP’,cascade=>TRUE);  — 收集该表的统计信息
PL/SQL procedure successfully completed.
SQL> select B.SEGMENT_NAME, B.blocks,B.blocks * 8096 / 1024 / 1024, A.BLOCKS,A.blocks * 8096 / 1024 / 1024, A.EMPTY_BLOCKS from user_tables a, USER_SEGMENTS B WHERE TABLE_NAME = ‘TEST_EMP’ AND A.TABLE_NAME = B.SEGMENT_NAME;
SEGMENT_NAME                                                                          BLOCKS B.BLOCKS*8096/1024/1024    BLOCKS A.BLOCKS*8096/1024/1024 EMPTY_BLOCKS
——————————————————————————— ———- ———————– ———- ———————– ————
TEST_EMP                                                                            1315840              10159.5313        46              .355163574            0
SQL> SELECT segment_name, SUM(bytes) / 1024 / 1024 Mbytes  FROM dba_segments WHERE    PARTITION_NAME = ‘PT_1’ GROUP BY segment_name;
SEGMENT_NAME                                                                          MBYTES
——————————————————————————— ———-
TEST_EMP                                                                              10288
BIN$VibHVCPfDL/gU8gCqMDDfw==$0                                                            8

– 注意:从上面可以看出,该表的大小是 10G,但是该表占用 blocks 只有 46 个,显然 有很多空间没有被使用,

⑥:释放未被使用的空间(我对该操作过了 10046 事件,在实际操作中只需执行:alter table test_emp modify partition pt_1 deallocate unused;)

SQL> alter session set tracefile_identifier=’10046′;
SQL> alter session set events ‘10046 trace name context forever,level 12’;  — 开启 10046 事件
Session altered.
SQL>
SQL>  alter table test_emp modify partition pt_1 deallocate unused;  — 执行该命令释放子分区未被使用的空间;
 
Table altered.
SQL> alter session set events ‘10046 trace name context off’;  — 关闭 10046 事件
Session altered.
SQL> select value from v$diag_info where name=’Default Trace File’;
VALUE
——————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————————–
/opt/oracle/diag/rdbms/dbs/dbs/trace/dbs_ora_3263_10046.trc

⑦:验证空间是否被释放:

SQL> select B.SEGMENT_NAME, B.blocks,B.blocks * 8096 / 1024 / 1024, A.BLOCKS,A.blocks * 8096 / 1024 / 1024, A.EMPTY_BLOCKS from user_tables a, USER_SEGMENTS B WHERE TABLE_NAME = ‘TEST_EMP’ AND A.TABLE_NAME = B.SEGMENT_NAME;
SEGMENT_NAME                                                                          BLOCKS B.BLOCKS*8096/1024/1024    BLOCKS A.BLOCKS*8096/1024/1024 EMPTY_BLOCKS
——————————————————————————— ———- ———————– ———- ———————– ————
TEST_EMP                                                                                1024                7.90625        46              .355163574            0

SQL> SELECT segment_name, SUM(bytes) / 1024 / 1024 Mbytes  FROM dba_segments WHERE    PARTITION_NAME = ‘PT_1’ GROUP BY segment_name;
SEGMENT_NAME                                                                          MBYTES
——————————————————————————— ———-
TEST_EMP                                                                                  16
BIN$VibHVCPfDL/gU8gCqMDDfw==$0                                                            8
—————————— ———— ———- ———- ———- ——————-
SYSAUX                                94.44        510      28.38    481.63 2017-08-07 17:19:30
SYSTEM                                93.24        800      54.06    745.94 2017-08-07 17:19:30
USERS                                26.25          5      3.69      1.31 2017-08-07 17:19:30
UNDOTBS1                              5.73        470    443.06      26.94 2017-08-07 17:19:30
TEST                                    .05      20480      20470        10 2017-08-07 17:19:30

从上面可以看出,该表的大小变成了 16M,而 blocks 也有 1024 个;表未被使用的空间已经释放,而且表空间可用大小也已经变大:

正文完
星哥玩云-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2022-01-22发表,共计7544字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中

星哥玩云

星哥玩云
星哥玩云
分享互联网知识
用户数
4
文章数
19351
评论数
4
阅读量
8006761
文章搜索
热门文章
星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛NAS-6:抖音视频同步工具,视频下载自动下载保存

星哥带你玩飞牛 NAS-6:抖音视频同步工具,视频下载自动下载保存 前言 各位玩 NAS 的朋友好,我是星哥!...
星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛NAS-3:安装飞牛NAS后的很有必要的操作

星哥带你玩飞牛 NAS-3:安装飞牛 NAS 后的很有必要的操作 前言 如果你已经有了飞牛 NAS 系统,之前...
我把用了20年的360安全卫士卸载了

我把用了20年的360安全卫士卸载了

我把用了 20 年的 360 安全卫士卸载了 是的,正如标题你看到的。 原因 偷摸安装自家的软件 莫名其妙安装...
再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见zabbix!轻量级自建服务器监控神器在Linux 的完整部署指南

再见 zabbix!轻量级自建服务器监控神器在 Linux 的完整部署指南 在日常运维中,服务器监控是绕不开的...
飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛NAS中安装Navidrome音乐文件中文标签乱码问题解决、安装FntermX终端

飞牛 NAS 中安装 Navidrome 音乐文件中文标签乱码问题解决、安装 FntermX 终端 问题背景 ...
阿里云CDN
阿里云CDN-提高用户访问的响应速度和成功率
随机文章
告别Notion焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁”

告别Notion焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁”

  告别 Notion 焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁” 引言 在数字笔记工...
星哥带你玩飞牛NAS-7:手把手教你免费内网穿透-Cloudflare tunnel

星哥带你玩飞牛NAS-7:手把手教你免费内网穿透-Cloudflare tunnel

星哥带你玩飞牛 NAS-7:手把手教你免费内网穿透 -Cloudflare tunnel 前言 大家好,我是星...
国产开源公众号AI知识库 Agent:突破未认证号限制,一键搞定自动回复,重构运营效率

国产开源公众号AI知识库 Agent:突破未认证号限制,一键搞定自动回复,重构运营效率

国产开源公众号 AI 知识库 Agent:突破未认证号限制,一键搞定自动回复,重构运营效率 大家好,我是星哥,...
终于收到了以女儿为原型打印的3D玩偶了

终于收到了以女儿为原型打印的3D玩偶了

终于收到了以女儿为原型打印的 3D 玩偶了 前些日子参加某网站活动,获得一次实物 3D 打印的机会,于是从众多...
让微信公众号成为 AI 智能体:从内容沉淀到智能问答的一次升级

让微信公众号成为 AI 智能体:从内容沉淀到智能问答的一次升级

让微信公众号成为 AI 智能体:从内容沉淀到智能问答的一次升级 大家好,我是星哥,之前写了一篇文章 自己手撸一...

免费图片视频管理工具让灵感库告别混乱

一言一句话
-「
手气不错
国产开源公众号AI知识库 Agent:突破未认证号限制,一键搞定自动回复,重构运营效率

国产开源公众号AI知识库 Agent:突破未认证号限制,一键搞定自动回复,重构运营效率

国产开源公众号 AI 知识库 Agent:突破未认证号限制,一键搞定自动回复,重构运营效率 大家好,我是星哥,...
仅2MB大小!开源硬件监控工具:Win11 无缝适配,CPU、GPU、网速全维度掌控

仅2MB大小!开源硬件监控工具:Win11 无缝适配,CPU、GPU、网速全维度掌控

还在忍受动辄数百兆的“全家桶”监控软件?后台偷占资源、界面杂乱冗余,想查个 CPU 温度都要层层点选? 今天给...
还在找免费服务器?无广告免费主机,新手也能轻松上手!

还在找免费服务器?无广告免费主机,新手也能轻松上手!

还在找免费服务器?无广告免费主机,新手也能轻松上手! 前言 对于个人开发者、建站新手或是想搭建测试站点的从业者...
浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍

浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍

浏览器自动化工具!开源 AI 浏览器助手让你效率翻倍 前言 在 AI 自动化快速发展的当下,浏览器早已不再只是...
告别Notion焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁”

告别Notion焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁”

  告别 Notion 焦虑!这款全平台开源加密笔记神器,让你的隐私真正“上锁” 引言 在数字笔记工...