iis服务器助手广告广告
返回顶部
首页 > 资讯 > 数据库 >删除一张大表时为什么undo占用空间接近原表两倍
  • 649
分享到

删除一张大表时为什么undo占用空间接近原表两倍

2024-04-02 19:04:59 649人浏览 薄情痞子
摘要

这篇文章将为大家详细讲解有关删除一张大表时为什么undo占用空间接近原表两倍,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。概述oracle中,undo是保存

这篇文章将为大家详细讲解有关删除一张大表时为什么undo占用空间接近原表两倍,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

概述

oracle中,undo是保存记录的前镜像的,我理解如果delete from  t;那产生的undo应该和t表的大小差不多,但测试结果却差的很远,undo产生的量基本上是t表大小的两倍,不知道为什么,难道我理解错了?下面看下这个奇怪的现象。

删除一张大表时为什么undo占用空间接近原表两倍

1. delete了8个小时

删除一张大表时为什么undo占用空间接近原表两倍

2. 原表大小

可以发现原表也就16.5G,需要删的数据是9G。

删除一张大表时为什么undo占用空间接近原表两倍

3. 查看undo块

这里忘记截图了,但是是有300多万个块,查看对应占用的undo空间是占了30多G,远远超过原表的大小。

为什么undo会占用这么多空间?

从原理上讲,UNDO表空间,有四个作用:

  • 回滚事务;

  • 一致性读;

  • 事务恢复;

  • 闪回查询

请教杨长老得到的一些信息:

对于回滚事务,他保存的是修改值的前镜像,注意,不是修改的数据块,或者整行记录的镜像。

除了考虑表大小之外,还有表上索引的总大小,是否存在触发器,物化试图日志等等。另外,看看数据库级的supplemental log是否打开。

undo是记录事物修改前镜像的,而delete的前镜像就是表中存储的数据。当然有一些可能会导致前镜像比表中的原始数据大,比如压缩,11g后存在的非空默认值。

另外,undo的记录一定有一些额外的成本,比如rowid,scn等信息,如果表中行记录本身很小,那么这些成本就会显得非常突出。

如果要非常精确地知道,多出来的每一个信息是多少,确实有些困难,但通过这个实验,至少能了解到,一次delete操作删除的容量,UNDO为了保存前镜像,需要占据的容量,要比他多得多,这就是为什么不推荐一次delete操作删除过多数据的原因之一。

总之,对于delete大量数据的情况一定要分批进行,宁愿时间花多点,风险也会少很多,避免意外导致回滚而造成的数据库卡顿。

关于删除一张大表时为什么undo占用空间接近原表两倍就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

您可能感兴趣的文档:

--结束END--

本文标题: 删除一张大表时为什么undo占用空间接近原表两倍

本文链接: https://www.lsjlt.com/news/68067.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 删除一张大表时为什么undo占用空间接近原表两倍
    这篇文章将为大家详细讲解有关删除一张大表时为什么undo占用空间接近原表两倍,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。概述Oracle中,undo是保存...
    99+
    2024-04-02
  • 为什么MySQL 删除表数据 磁盘空间还一直被占用
    目录1、Mysql数据结构2、表文件大小未更改和mysql设计有关3、那怎么才能让表大小变小4、Online DDL5、总结最近有个上位机获取下位机上报数据的项目,由于上报频率比较频...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作