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

news/2024/7/27 7:44:32/文章来源:https://blog.csdn.net/lzyever/article/details/136485647

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_998861.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

向量的内积、长度、正交性

目录 向量的内积 向量的长度&#xff08;模&#xff09; 标准正交基 标准正交化 正交矩阵 向量的内积 向量的长度&#xff08;模&#xff09; 标准正交基 标准正交化 正交矩阵

FPGA IBUFG

IBUFG和IBUFGDS的输入端仅仅与芯片的专用全局时钟输入管脚有物理连接&#xff0c;与普通IO和其它内部CLB等没有物理连接。 所以&#xff0c;IBUFG输入的不能直接接另外信号。 GTH transceiver primitives are called GTHE3_COMMON and GTHE3_CHANNEL in UltraScale FPGAs, an…

室内设计AI绘画关键词怎么设置?

在室内设计AI绘画中&#xff0c;关键词的设置对于生成高质量的图片至关重要。以下是关于如何设置AI绘画关键词的一些建议&#xff1a; 首先&#xff0c;明确自己的需求&#xff0c;比如是想要生成什么样的室内设计风格&#xff0c;是简约现代、复古风还是其他风格。然后&#x…

网络安全: Kali Linux 使用 docker-compose 部署 openvas

目录 一、实验 1.环境 2.Kali Linux 安装docker与docker-compose 3.Kali Linux 使用docker-compose方式部署 openvas 4. KaliLinux 使用openvas 二、问题 1. 信息安全漏洞库 2.信息安全漏洞共享平台 3.Windows 更新指南与查询 4.CVE 查询 5.docker-compose 如何修改o…

Python通过SFTP实现网络设备配置备份

一、背景 为了防止网络设备意外损坏&#xff0c;导致配置文件无法恢复&#xff0c;可以通过将网络设备的配置文件备份到本地电脑上。 一般情况下&#xff0c;设备支持通过FTP、TFTP、FTPS、SFTP和SCP备份配置文件。其中使用FTP和TFTP备份配置文件比较简单&#xff0c;但是存在…

React 事件机制原理

相关问题 React 合成事件与原生 DOM 事件的区别React 如何注册和触发事件React 事件如何解决浏览器兼容问题 回答关键点 React 的事件处理机制可以分为两个阶段&#xff1a;初始化渲染时在 root 节点上注册原生事件&#xff1b;原生事件触发时模拟捕获、目标和冒泡阶段派发合…

基于Springboot的无人智慧超市管理系统(有报告)。Javaee项目,springboot项目。

演示视频&#xff1a; 基于Springboot的无人智慧超市管理系统&#xff08;有报告&#xff09;。Javaee项目&#xff0c;springboot项目。 项目介绍&#xff1a; 采用M&#xff08;model&#xff09;V&#xff08;view&#xff09;C&#xff08;controller&#xff09;三层体系…

portainer管理远程docker和docker-swarm集群

使用前请先安装docker和docker-compose&#xff0c;同时完成docker-swarm集群初始化 一、portainer-ce部署 部署portainer-ce实时管理本机docker&#xff0c;使用docker-compose一键拉起 docker-compose.yml version: 3 services:portainer:container_name: portainer#imag…

HNU-算法设计与分析-甘晴void学习感悟

前言 算法设计与分析&#xff0c;仅就课程而言&#xff0c;似乎是数据结构与算法分析的延续 教材使用&#xff1a; 课程 关于课程&#xff0c;橙学长讲的非常清晰&#xff0c;我深以为然。 HNUCS-大三课程概览-CSDN博客文章浏览阅读1.3k次&#xff0c;点赞5次&#xff0c;收…

蓝桥杯2017年第八届真题-分巧克力

目录 题目描述 输入格式 输出格式 样例输入 样例输出 原题链接 代码实现 题目描述 儿童节那天有K位小朋友到小明家做客。小明拿出了珍藏的巧克力招待小朋友们。 小明一共有N块巧克力&#xff0c;其中第i块是Hi x Wi的方格组成的长方形。 为了公平起见&#xff0c;小明需…

在ubuntu上使用vscode+gcc-arm-none-eabi+openocd工具开发STM32

文章目录 所需工具安装调试搭建过程中遇到的问题 写在前面 老大上周让我用vscode开发STM32&#xff0c;我爽快的答应了&#xff0c;心想大学四年装了这么多环境了这不简简单单&#xff0c;更何况vscode这两年还用过&#xff0c;然而现实总是令人不快的——我竟然花了差不多两周…

超实用的公众号搭建教程分享,纯干货

微信公众号已经成为了企业、个人和品牌进行宣传和互动的重要平台。在这个拥有海量公众号的时代&#xff0c;如何让你的公众号脱颖而出&#xff0c;吸引更多的关注者&#xff0c;实现有效传播呢&#xff1f;接下来&#xff0c;伯乐网络传媒将为你详细解析公众号搭建教程&#xf…

一键查看:大厂网站都用了啥技术栈,有图有真相。

本次我们采用Wappalyzer插件来看下国内大厂的网站都采用了什么技术架构&#xff0c;文章最后由Wappalyzer的安装方法。 今日头条网站 淘宝网站 哔哩哔哩 京东商城 花瓣网 CSDN 国务院 网易 58同城 腾讯网 如何安装Wappalyzer 用Edge浏览器即可

几种电脑提示mfc140.dll丢失的解决方法,以及如何预防mfc140.dll丢失

mfc140.dll真是一个超级关键的动态链接库文件&#xff01;一旦这个文件不翼而飞&#xff0c;可能会导致一些程序无法顺利运行&#xff0c;甚至给系统带来麻烦。但别担心&#xff01;遇到mfc140.dll文件丢失的情况&#xff0c;我们有一堆应对措施可以立马施行&#xff0c;确保问…

双体系Java学习之逻辑运算符,三元运算符和运算符优先级

逻辑运算符 package operator;//逻辑运算符 public class Demo05 {public static void main(String[] args) {// 与&#xff08;and&#xff09;&& 或&#xff08;or&#xff09;|| 非&#xff08;取反&#xff09;boolean a true;boolean b false;System.out.printl…

企业举办活动发布会的意义是什么?如何利用媒体宣传

传媒如春雨&#xff0c;润物细无声&#xff0c;大家好&#xff0c;我是51媒体网胡老师。 企业举办活动发布会的意义与媒体宣传策略 一、发布会的意义&#xff1a; 信息传递&#xff1a;直接向公众和利益相关者发布重要信息。品牌塑造&#xff1a;展示企业文化和创新&#xff…

HTML—常用标签

常用标签&#xff1a; 标题标签&#xff1a;<h1></h1>......<h6></h6>段落标签&#xff1a;<p></p>换行标签&#xff1a;<br/>列表&#xff1a;无序列表<ul><li></li></ul> 有序列表<ol>&…

牛客小白月赛88

E.多重映射 解题思路 对集合进行整体操作&#xff0c;集合大小只增不减&#xff0c;问最后集合标号维护集合&#xff0c;考虑并查集但直接用并差集维护会有以下问题&#xff1a;当前集合变标号&#xff0c;可能会和之前标号相同&#xff0c;则进行并查集操作时&#xff0c;会接…

C++ 智能指针深度剖析

文章目录 1. 前言2. 为什么需要智能指针&#xff1f;3. 内存泄漏3.1 内存泄漏的概念及危害3.2 内存泄漏的分类3.3 如何检测内存泄漏3.4 如何避免内存泄漏 4. 智能指针的使用及原理4.1 RAII思想4.2 智能指针的原理4.3 C智能指针发展历史4.4 std::auto_ptr4.5 std::unique_ptr4.6…

驱动OLED SSD1306的笔记

这里用的OLED模块是SSD1306的 硬件 SSD1306只支持3.3V供电SSD1306支持4中接口&#xff1a;6800、 8080&#xff0c;SPI&#xff0c;IIC通过引脚BS1和BS2接口的模式。如果是IIC模式&#xff0c;SCL对应D0&#xff0c;SDA对应D1,D2(需要把D1和D2连在一起然后接入MCU的SDA) OLED…