Oracle中使用alter table move命令的方法降低表中的高水位(High Water Mark)

本文主要是介绍Oracle中使用alter table move命令的方法降低表中的高水位(High Water Mark),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Oracle中使用alter table move命令的方法降低表中的高水位(High Water Mark)

导读
在Oracle数据库中,“高水位”(High Water Mark)是指表中数据的存储位置已经达到的最高位置。在表中插入、更新或删除数据时,数据库会自动管理数据的存储位置,但是删除操作并不会立即释放空间,而是标记为可重用。高水位标记了表中已经被使用的存储位置的最高点,而这些位置之上的空间可以被重新利用,以存储新的数据。
当表中有大量的删除操作时,高水位可能会远远超过实际数据的位置,导致表的存储空间浪费。为了减少这种浪费,可以使用ALTER TABLE <table_name> MOVE命令来重新组织表,将高水位重新设置到实际数据的位置之上。这个操作会将表中的数据重新组织,并且释放未使用的存储空间。
需要注意的是,重新组织表可能会导致数据库性能下降,因为它需要重新组织数据并重建索引。因此,在执行此操作之前,最好在低负载时段进行,并且谨慎评估其对数据库性能的影响。
另外,有一些其他的方法也可以管理高水位,比如使用TRUNCATE TABLE来直接清空表并释放空间,或者使用ALTER TABLE <table_name> SHRINK SPACE来缩小表的存储空间。但是这些方法都可能会有一些限制或者副作用,因此在使用之前需要进行充分的了解和测试。

下面开始演示如何使用move命令来降低Oracle数据库的高水位线。

1、创建测试表test

create table test as select * from dba_objects;

2、统计表的行数

select count(*) from test;COUNT(*)
----------581761

3、统计表的块数

select blocks,empty_blocks,num_rows,avg_row_len from dba_tables where table_name='TEST';BLOCKS EMPTY_BLOCKS   NUM_ROWS AVG_ROW_LEN---------- ------------ ---------- -----------为空,这是因为没有搜集表的统计信息。

4、收集一下表的统计信息

ANALYZE TABLE TEST ESTIMATE STATISTICS;

5、再次查看表的块数

select blocks,empty_blocks,num_rows,avg_row_len from dba_tables where table_name='TEST';BLOCKS EMPTY_BLOCKS   NUM_ROWS AVG_ROW_LEN---------- ------------ ---------- -----------8026         2770     581455          97

6、查看表的高水位情况

SELECT table_name,ROUND((blocks * 8), 2) "高水位空间 k",ROUND((num_rows * avg_row_len / 1024), 2) "真实使用空间 k",ROUND((blocks * 10 / 100) * 8, 2) "预留空间(pctfree) k",ROUND((blocks * 8 - (num_rows * avg_row_len / 1024) - blocks * 8 * 10 / 100),2) "浪费空间 k"FROM dba_tablesWHERE table_name='TEST';
TABLE_NAME                     高水位空间 k 真实使用空间 k 预留空间(pctfree) k 浪费空间 k------------------------------ ------------ -------------- ------------------- ----------TEST                                  64208       55079.23              6420.8    2707.97

7、删除399999条记录

DELETE FROM TEST WHERE ROWNUM<400000;399999 rows deleted.COMMIT;

8、查看表的块数

select blocks,empty_blocks,num_rows,avg_row_len from dba_tables where table_name='TEST';BLOCKS EMPTY_BLOCKS   NUM_ROWS AVG_ROW_LEN---------- ------------ ---------- -----------8026         2770     581455          97

块数和行数均没有发生变化,是因为没有收集表的统计信息

9、收集表的统计信息

ANALYZE TABLE TEST ESTIMATE STATISTICS;

10、再次查看表的块数和行数

select blocks,empty_blocks,num_rows,avg_row_len from dba_tables where table_name='TEST';BLOCKS EMPTY_BLOCKS   NUM_ROWS AVG_ROW_LEN---------- ------------ ---------- -----------8026         2770     170975          97表的块数没有发生变化(高水位),表的行数减少了399999行。

11、降低高水位

ALTER TABLE TEST MOVE;

12、查看表的块数

select blocks,empty_blocks,num_rows,avg_row_len from dba_tables where table_name='TEST';BLOCKS EMPTY_BLOCKS   NUM_ROWS AVG_ROW_LEN---------- ------------ ---------- -----------8026         2770     170975          97

表的块数没有降低

13、收集一下表的统计信息

ANALYZE TABLE TEST ESTIMATE STATISTICS;

14、再次查看表的块数

select blocks,empty_blocks,num_rows,avg_row_len from dba_tables where table_name='TEST';BLOCKS EMPTY_BLOCKS   NUM_ROWS AVG_ROW_LEN---------- ------------ ---------- -----------2351          852     171822          96

表的块数已经降低了。

15、查看表的高水位情况

SELECT table_name,ROUND((blocks * 8), 2) "高水位空间 k",ROUND((num_rows * avg_row_len / 1024), 2) "真实使用空间 k",ROUND((blocks * 10 / 100) * 8, 2) "预留空间(pctfree) k",ROUND((blocks * 8 - (num_rows * avg_row_len / 1024) - blocks * 8 * 10 / 100),2) "浪费空间 k"FROM dba_tablesWHERE table_name='TEST';
TABLE_NAME                     高水位空间 k 真实使用空间 k 预留空间(pctfree) k 浪费空间 k------------------------------ ------------ -------------- ------------------- ----------TEST                                  18808       16108.31              1880.8     818.89

这篇关于Oracle中使用alter table move命令的方法降低表中的高水位(High Water Mark)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/780338

相关文章

nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析(结合应用场景)

《nginx-t、nginx-sstop和nginx-sreload命令的详细解析(结合应用场景)》本文解析Nginx的-t、-sstop、-sreload命令,分别用于配置语法检... 以下是关于 nginx -t、nginx -s stop 和 nginx -s reload 命令的详细解析,结合实际应

C#连接SQL server数据库命令的基本步骤

《C#连接SQLserver数据库命令的基本步骤》文章讲解了连接SQLServer数据库的步骤,包括引入命名空间、构建连接字符串、使用SqlConnection和SqlCommand执行SQL操作,... 目录建议配合使用:如何下载和安装SQL server数据库-CSDN博客1. 引入必要的命名空间2.

使用Python删除Excel中的行列和单元格示例详解

《使用Python删除Excel中的行列和单元格示例详解》在处理Excel数据时,删除不需要的行、列或单元格是一项常见且必要的操作,本文将使用Python脚本实现对Excel表格的高效自动化处理,感兴... 目录开发环境准备使用 python 删除 Excphpel 表格中的行删除特定行删除空白行删除含指定

深入理解Go语言中二维切片的使用

《深入理解Go语言中二维切片的使用》本文深入讲解了Go语言中二维切片的概念与应用,用于表示矩阵、表格等二维数据结构,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习吧... 目录引言二维切片的基本概念定义创建二维切片二维切片的操作访问元素修改元素遍历二维切片二维切片的动态调整追加行动态

prometheus如何使用pushgateway监控网路丢包

《prometheus如何使用pushgateway监控网路丢包》:本文主要介绍prometheus如何使用pushgateway监控网路丢包问题,具有很好的参考价值,希望对大家有所帮助,如有错误... 目录监控网路丢包脚本数据图表总结监控网路丢包脚本[root@gtcq-gt-monitor-prome

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

Linux系统性能检测命令详解

《Linux系统性能检测命令详解》本文介绍了Linux系统常用的监控命令(如top、vmstat、iostat、htop等)及其参数功能,涵盖进程状态、内存使用、磁盘I/O、系统负载等多维度资源监控,... 目录toppsuptimevmstatIOStatiotopslabtophtopdstatnmon

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期