在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

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

92次阅读
没有评论

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

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

概述

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

1. delete 了 8 个小时

2. 原表大小

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

3. 查看 undo 块

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

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

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

回滚事务;

一致性读;

事务恢复;

闪回查询

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

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

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

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

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

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

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

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

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-07-17发表,共计899字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 国产午夜精品久久久久免费视小说 | 91精品欧美一区二区三区 | 亚洲乱亚洲乱妇 | 免费福利视频在线观看 | 亚洲香蕉网综合久久 | 呦女精品视频 | 男女很舒服爽视频免费 | 性做久久久久久久久25的美女 | 逼逼好嫩视频 | 精品久久久中文字幕一区 | 色窝窝亚洲av网在线观看 | 久久一本岛在免费线观看2020 | 午夜啪啪片| 成人欧美在线观看免费视频 | 一级毛片日韩a欧美最爱 | 久久久亚洲精品国产 | 精品无码一区二区三区亚洲桃色 | 久久夜色精品国产噜噜 | 曰韩亚洲av人人夜夜澡人人爽 | 久久一区二区免费播放 | 国内老熟妇对白xxxxhd | 中文天堂资源在线www | 精品人妻无码一区二区三区 | 中文在线中文a | 岳丰满多毛的大隂户 | 国产欧美日韩综合 | 亚洲av午夜成人片精品电影 | 久久99影院网久久久久久 | 国产一级特黄高清免费大片 | 成人欧美日韩一区二区三区 | 狠狠色噜噜狠狠狠狠av不卡 | 亚洲人成网站在线 | 制服丝袜美腿一区二区 | 伦理片高清在线观看网站 | 综合久久国产九一剧情麻豆 | 精品一区二区高清在线观看 | 女人被狂躁的高潮免费视频 | 在线看片日本 | 精久国产一区二区三区四区 | 偷自拍 | 看全色黄大色黄大片 视频 看全色黄大色黄大片毛片 看全色黄大色黄大片色黄看的 |