余晖落尽暮晚霞,黄昏迟暮远山寻
本站
当前位置:网站首页 > 编程知识 > 正文

云贝教育|「技术文章」temp redo undo 测试

xiyangw 2023-10-09 16:27 50 浏览 0 评论

作者:刘晓峰

原文链接:http://www.tdpub.cn/Blog/detail/id/1294.html


1.什么时机产生UNDO和REDO

有DML就会产生UNDO,有UNDO就会产生此UNDO对应REDO

执行DML,再执行COMMIT是把位于内存的日志缓存区数据转储到磁盘的在线重做日志组

执行了COMMIT,不一定会修改磁盘数据,磁盘数据的DBWn进程触发机制不依赖COMMIT.

UNDO是回滚段,磁盘上

测量REDO是测量REDO LOG FILE 还是 REDO BUFFER ?虽然他们的结果应该是相等的


2.什么样的操作不会产生UNDO和REDO?

UNDO用于事务回滚,所以DML语句一般都会产生UNDO(直接路径加载+nologging不会产生或者产生很少的UNDO和REDO)

REDO用于事务恢复,临时表上的数据用完即丢,所以临时表上的DML不产生REDO,但是临时表发生DML的时候会产生UNDO(因为临时表上也可以执行rollback,有回滚就肯定有UNDO),这部分UNDO会产生REDO


3.临时表最好只进行INSERT 和SELECT

原因:

虽然临时表本身的操作不会产生REDO,会产生UNDO以及这部分UNDO的REDO,所以如何减小UNDO,DELETE产生的UNDO最多,而UPDATE对索引影响比较大,因此如果临时表上有索引,此部分索引的修改也会产生UNDO,也会针对这部分UNDO产生REDO


4.如何最小化临时表的REDO产生

ALTER SYSTEM/SESSION SET TEMP_UNDO_ENABLED =TRUE

前面我们知道临时表的操作,UNDO产生不能避免,不过还是会产生一点点REDO,能不把这一点点REDO也去掉。

我们知道临时表的操作是发生在临时表表空间,临时表空间的DML操作不会产生REDO。是临时表空间的UNDO会产生REDO,原因是UNDO是放在UNDO表空间,如果我们把临时表对应的UNDO也放在临时表空间,而不是UNDO表空间,那么这一点点REDO也不会产生了


5.测量开启 TEMP_UNDO_ENABLED前后的REDO,UNDO变化

结论:临时表写入1M数据。开启TEMP_UNDO_ENABLED之后,事务产生的REDO从140K降低为0.1KB

--为了方便换算,写1m的数据进行测试

create global TEMPORARY TABLE tem_test(a varchar2(1024)) on commit preserve rows ;

--创建普通表

create TABLE tem_test_normal(a varchar2(1024)) ;

--简单起见只测量insert,DML中insert最多的REDO,最少的UNDO,UNDO数量级应该和存储ROWID需要的字节量一致

--使用跟踪打印出来的redo更准确

--==========================================================
--新开窗口1--START
begin
for i in 1..1024 loop
insert into tem_test(a)values(rpad('X',1024,'X'));
end loop;
end;
--redo 632->151716 :0.14m redo
SELECT a.name
,b.value
FROM v$statname a
,v$sesstat b
WHERE a.statistic# = b.statistic#
AND A.NAME = 'redo size'
AND B.SID=USERENV('SID')
--事务产生的undo 0-73728:0.07m UNDO
SELECT t.used_ublk*8*1024
FROM v$session s
,v$transaction t
WHERE s.saddr = t.ses_addr
AND s.sid = userenv('SID');
--新开窗口1---END
--==========================================================
--新开窗口2---START
ALTER SESSION SET TEMP_UNDO_ENABLED =TRUE;
begin
for i in 1..1024 loop
insert into tem_test(a)values(rpad('X',1024,'X'));
end loop;
end;
--redo 676->948 : 很少
SELECT a.name
,b.value
FROM v$statname a
,v$sesstat b
WHERE a.statistic# = b.statistic#
AND A.NAME = 'redo size'
AND B.SID=USERENV('SID')
--事务产生的undo 0-8192:8KB UNDO
SELECT t.used_ublk*8*1024
FROM v$session s
,v$transaction t
WHERE s.saddr = t.ses_addr
AND s.sid = userenv('SID');
--查询
select * from v$tempundostat
--新开窗口2---END
--==========================================================
--新开窗口3---START
begin
for i in 1..1024 loop
insert into tem_test_normal(a)values(rpad('X',1024,'X'));
end loop;
end;
--redo 676->1435724 :1.36m redo
SELECT a.name
,b.value
FROM v$statname a
,v$sesstat b
WHERE a.statistic# = b.statistic#
AND A.NAME = 'redo size'
AND B.SID=USERENV('SID')
--事务产生的undo 0-81920: 80k UNDO
SELECT t.used_ublk*8*1024
FROM v$session s
,v$transaction t
WHERE s.saddr = t.ses_addr
AND s.sid = userenv('SID');
--新开窗口1---END
select sum(lengthb(rowid))/1024||'KB' from tem_test_normal;--应该是10K-100K左右
--========================================================= 

相关推荐

华为交换机配置命令总结

1、配置文件相关命令[Quidway]displaycurrent-configuration显示当前生效的配置[Quidway]displaysaved-configuration显示fla...

解决账户无法登录的故障
解决账户无法登录的故障

在优化系统时错误地根据网上的提示,将唯一的Administrator账户设置为禁用,导致重启后无法进入系统。类似的故障还有使用组策略限制本地账户登录,导致重启后...

2023-10-11 17:16 xiyangw

S5720交换机登录提示初始密码存在安全风险
S5720交换机登录提示初始密码存在安全风险

问题描述客户每次登录输密码时,提示初始密码不安全,现在客户嫌麻烦想要去掉:Username:huaweiPassword:Warning:Theinitia...

2023-10-11 17:15 xiyangw

Springboot,Mybatis修改登录用户的密码
Springboot,Mybatis修改登录用户的密码

一、Mybatis.xml<updateid="changePassword"parameterType="string...

2023-10-11 17:15 xiyangw

PHP理论知识之沐浴更衣重看PHP基础(二)
PHP理论知识之沐浴更衣重看PHP基础(二)

接上篇,咱们继续讲解PHP基础八、标准PHP组件和框架的数量很多,随之产生的问题就是:单独开发的框架没有考虑到与其他框架的通信。这样对开发者和框架本身都是不利的...

2023-10-11 17:15 xiyangw

新鲜出炉UCloud云主机“数据方舟”评测报告(5)— — 关其城
新鲜出炉UCloud云主机“数据方舟”评测报告(5)— — 关其城

2015年10月29日,UCloud云主机黑科技——“数据方舟”功能正式上线,首轮内测随即开放。截止至2015年12月6日,我们共收到了534位用户的评测申...

2023-10-11 17:14 xiyangw

业余无线电Q简语及英文缩语
业余无线电Q简语及英文缩语

Q简语:语音通信及CW通信通用(加粗为常用)QRA电台何台QRB电台间之距离QRG告之正确频率QRH频率是否变动QRI发送音调QRJ能否收到QRK信号之可...

2023-10-11 17:14 xiyangw

非常详细!如何理解表格存储的多版本、生命周期和有效版本偏差
非常详细!如何理解表格存储的多版本、生命周期和有效版本偏差

表格存储在8月份推出了容量型实例,直接支持了表级别最大版本号和生命周期,高性能实例也将会在9月中旬支持这两个特性。那么,最大版本号和生命周期以及特有的...

2023-10-11 17:14 xiyangw

H3C交换机恢复出厂和各种基本配置,这20个要点你知道吗?
H3C交换机恢复出厂和各种基本配置,这20个要点你知道吗?

私信“干货”二字,即可领取138G伺服与机器人专属及电控资料!H3C交换机不知道密码如何恢复出厂设置1、开机启动,Ctrl+B进入bootrom菜单,选择恢复出...

2023-10-11 17:13 xiyangw

在使用移动支付系统的时候如何保护信息安全?

移动支付的方式近年来不断被更新,使得Venmo(据嘉丰瑞德理财师了解,此为美国的“支付宝”)之类的支付方式已经可以某种意义上代替随身携带现金了。但是你必须防范那些第三方应用程序轻松地获取你的银行卡以及...

界面控件DevExpress WinForms MVVM入门指南——登录表单(下)

从本文档中,您将了解如何向应用程序添加登录表单。在本节教程中着重讨论了如何实现此任务,这基本上是附加应用程序功能的一部分。DevExpressUniversalSubscription官方最新版免...

linux基础命令(一)
linux基础命令(一)

为啥要学linux?您可能熟悉WindowsXP、Windows7、Windows10和MacOSX等操作系统。Linux就是这样一种强大的操...

2023-10-11 17:13 xiyangw

MySQL数据库密码忘记了,怎么办?

#头条创作挑战赛#MySQL数据库密码忘记了且没有其他可以修改账号密码的账户时怎么办呢?登录MySQL,密码输入错误/*密码错误,报如下错误*/[root@TESTDB~]#mysql-u...

MobaXterm忘记Session密码,如何查看已保存的密码
MobaXterm忘记Session密码,如何查看已保存的密码

MobaXterm工具登录过SSH终端后,如果存储了Session(存储后再连接ssh的时候只需要输入账号不需要输入密码就可以直接连接上ssh),则可以...

2023-10-11 17:12 xiyangw

华为交换机密码丢失修改方法
华为交换机密码丢失修改方法

华为S2300交换机找回密码设置一、目的交换机的console和telnet密码丢失,无法登录设备。交换机已进行过数据配置,要把密码恢复而数据配置不能丢失。二、...

2023-10-11 17:12 xiyangw

取消回复欢迎 发表评论: