百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

Oracle大数据量delete清空数据后查询依旧很慢

yuyutoo 2024-12-18 17:58 3 浏览 0 评论

【问题】原有一千万条数据表,delete 后仅保留了一天的数据,32条记录select竟然耗时34秒。

【分析】

1、根据以往经验的估计delete时没有恢复oracle的高水位线。

2、以下为参考资料

在Oracle数据的存储中,可以把存储空间想象为一个水库,数据想象为水库中的水。水库中的水的位置有一条线叫做水位线,在Oracle中,这条线被称为高水位线(High-warter mark, HWM)。在数据库表刚建立的时候,由于没有任何数据,所以这个时候水位线是空的,也就是说HWM为最低值。当插入了数据以后,高水位线就会上涨,但是这里也有一个特性,就是如果你采用delete语句删除数据的话,数据虽然被删除了,但是高水位线却没有降低,还是你刚才删除数据以前那么高的水位。也就是说,这条高水位线在日常的增删操作中只会上涨,不会下跌。下面我们来谈一下Oracle中Select语句的特性。Select语句会对表中的数据进行一次扫描,但是究竟扫描多少数据存储块呢,这个并不是说数据库中有多少数据,Oracle就扫描这么大的数据块,而是Oracle会扫描高水位线以下的数据块。现在来想象一下,如果刚才是一张刚刚建立的空表,你进行了一次Select操作,那么由于高水位线HWM在最低的0位置上,所以没有数据块需要被扫描,扫描时间会极短。而如果这个时候你首先插入了一千万条数据,然后再用delete语句删除这一千万条数据。由于插入了一千万条数据,所以这个时候的高水位线就在一千万条数据这里。后来删除这一千万条数据的时候,由于delete语句不影响高水位线,所以高水位线依然在一千万条数据这里。这个时候再一次用select语句进行扫描,虽然这个时候表中没有数据,但是由于扫描是按照高水位线来的,所以需要把一千万条数据的存储空间都要扫描一次,也就是说这次扫描所需要的时间和扫描一千万条数据所需要的时间是一样多的。所以有时候有人总是经常说,怎么我的表中没有几条数据,但是还是这么慢呢,这个时候其实奥秘就是这里的高水位线了。


【结论】

六种方法降低水位线

1.执行表重建指令 alter table table_name move;

2.执行alter table table_name shrink space; 注意,此命令为Oracle 10g新增功能,再执行该指令之前必须允许行移动alter table table_name enable row movement;

3.复制要保留的数据到临时表t,drop原表,然后rename临时表t为原表

4.emp/imp

5.alter table table_name deallocate unused

6.尽量truncate吧

32条记录select降低至0.08秒

相关推荐

详细指南:如何在本地或服务器上安装Z-Blog博客系统

怎么安装Z-Blog(HowtoInstallZ-Blog)  Z-Blog是一款功能强大的博客系统,因其简单易用和灵活性受到许多用户的喜爱。本文将详细介绍如何在本地或服务器上安装Z-Blog,...

群晖NAS安装wordpress博客,构建属于自己的web网站

学习网络技术的话可以关注我,每天都会有相应的教程发布的!群晖NAS主要的作用就是网络储存,你可以理解为百度云,但这个百度云的服务器放在了家里。个人而言,有了NAS以后,家里的所有设备(台式电脑,笔记本...

MySQL8安装 八: 使用phpMyadmin客户端

MySQL8安装一:源码安装...

ThinkPHP6开发博客实战入门(一),集成环境的安装与配置

本套入门教程适合想学php或者thinkphp却无从下手的同学,那么恭喜你,你只需要按照本套教程实战操作一遍,就会有意想不到的收获。我教程的特色是很少讲理论知识,主要偏重功能实战。我只会告诉你用怎样的...

蒸汽流量计远程控制系统的调试与应用

1、系统的联合调试蒸汽流量计上位机控制系统的调试主要包括服务器与数据库、各站点的连接调试。在与数据库连接调试中,本文选用一种被广泛使用的phpMyAdmin工具软件,实现对MySQL数据库图形化管理,...

我用NAS部署人力资源管理项目——管理人员就这么简单

?...

有MacBook电脑,自学PHP详细步骤

自学PHP编程并在MacBook上设置好环境,是一个比较简单的过程。你可以按照以下步骤一步步开始你的学习之旅:1.安装PHPMacBook通常预装有PHP,但可以确认一下版本并更新到最...

如何从零开始创建一个功能强大的ZBlog网站指南

ZBlog怎么创建(HowtoCreateZBlog)  ZBlog是一款非常流行的博客系统,因其简洁易用和强大的功能受到许多博主的喜爱。本文将详细介绍如何从零开始创建一个ZBlog网站,包括...

phpMyAdmin 5.0.0正式发布:移除对5.5/5.6/7.0等旧版PHP支持

phpMyAdmin5.0.0版本于今天正式发布。该版本同4.9.3版本同时存在,不过官方推荐没有安装旧版PHP的用户尽量使用5.0.0版本。本次5.0版本更新中在涵盖了4.9分支的大量改进之外,还...

黑客学习搭建社工库nas黑群晖部署安装apache+php+mysql个人网站

今天分享给大家如何利用群晖自带的web功能,来搭建一个属于自己的个人网站群晖环境:首先进入套件中心,1、下载安装webstation2、下载安装php53、下载安装apache2.44、下载安装Ma...

phpMyAdmin使用教程(图文详解)

什么是phpMyAdmin?phpMyAdmin是众多MySQL图形化管理工具中使用最为广泛的一种,是一款使用PHP开发的基于B/S模式的MySQL客户端软件,该工具是基于Web跨平台的管理程序,并且...

ZBlog PHP迁移指南:步骤、注意事项与常见问题解决方案总结

ZBlogPHP迁移指南(ZBlogPHPMigrationGuide)  ZBlog是一个功能强大的博客系统,广泛用于个人博客和企业网站。随着网站的发展,用户可能需要将其ZBlogP...

0成本打造私人文档管理系统,这个开源工具让你省下万元订阅费

在这个数字化时代,我们每天都在处理大量的文件和文档,随着时间推移,这些纸质文件不断堆积,不仅占用大量空间,查找起来非常让人头疼。你是否也曾因为找不到重要文件而焦虑不已?或是被满屋子的文件弄得焦头烂额?...

群晖NAS安装MySQL数据库及phpMyAdmin实现远程管理本地数据库

前言本文主要介绍如何在群晖NAS安装MySQL与数据库管理软件phpMyAdmin,并结合cpolar内网穿透工具配置公网地址,实现异地远程访问本地部署的phpMyAdmin详细流程。...

广受追捧MFC界面开发库BCGControlBar如何安装?

1.BCGControlBar简介1.1概述BCG是MFC的一个扩展库,可以用来构建类似于MicrosoftOffice2003/2007/2010/2013/2016和Microsoft...

取消回复欢迎 发表评论: