我对Oracle的刷未提交数据到文件的学习体会

简介:

开始

学习网上文章:http://blog.csdn.net/linwaterbin/article/details/7823519

我自己所作的实验。

首先根据网络上搜索的结论,DBWR会在如下几种情况下写数据:

复制代码
什么时候dbwr会把数据写入数据文件呢?下面这几种情况:

1.当Buffer Cache中的Dirty List长度达到阀值:DBWR将Dirty List中的Dirty Buffer写入磁盘(user Server Process在LRU List中查找free buffer时将碰到的dirty blocks移入Dirty List)
2.当user Server Process在Buffer Cache的LRU List中搜索了过长的时间而仍然没有找到free buffer:DBWR直接从LRU List中将Dirty Buffer写入磁盘 3.每过3秒钟:DBWR把dirty buffers从LRU List移到Dirty List,一旦Dirty List长度达到阀值,DBWR便将数据写入磁盘 4.Checkpoint发生时:DBWR把所有的dirty buffers从LRU List移到Dirty List,并且开始写数据
5.当Tablespace开始Hot backup时:DBWR把所有属于该表空间的dirty buffers从LRU List移到Dirty List,并且开始写数据
6.当Tablespace offline时:DBWR把所有属于该表空间的dirty buffers从LRU List移到Dirty List,并且开始写数据
7.执行Drop时:drop table或者index将促使DBWR先将属于该segment的dirty blocks写入磁盘
复制代码

上述描述表明,DBWR动作和是否commit 没有 必然的联系。下面是我的实验和扩展实验。

第一个session:

 说明没有事务活动。

SQL> select xidusn, xidslot,xidsqn,ubafil,ubablk from v$transaction;                        
                        
no rows selected                        
                        
SQL>                         

第二个session:

复制代码
SQL> create table testtab(id integer,name char(1)) tablespace users;   
Table created.
SQL> 
SQL
> insert into testtab values(1,'a'); 1 row created. SQL> insert into testtab values(2,'b'); 1 row created. SQL> insert into testtab values(3,'c'); 1 row created. SQL> commit; SQL> update testtab set name='d' where id=1; 1 row updated. SQL>
复制代码

此时没有提交对 id=1 的 name='d' 的修改。

回到 session 1:

复制代码
SQL> select dbms_rowid.rowid_relative_fno(rowid) as fno,                                
  2  dbms_rowid.rowid_block_number(rowid) block, t.* from testtab t;                    
                    
       FNO      BLOCK         ID N                    
---------- ---------- ---------- -                    
         4      20927          1 a                    
         4      20927          2 b                    
         4      20927          3 c                                        
SQL>                     
                    
SQL> select FILE#,NAME from V$datafile;       
                    
     FILE#                    
----------                    
NAME                    
--------------------------------------------------------------------------------                    
1                    
/home/oracle/app/oracle/oradata/orcl/system01.dbf                    
                    
2                    
/home/oracle/app/oracle/oradata/orcl/sysaux01.dbf                    
                    
3                    
/home/oracle/app/oracle/oradata/orcl/undotbs01.dbf                    
                                        
     FILE#                    
----------                    
NAME                    
--------------------------------------------------------------------------------                    
4                    
/home/oracle/app/oracle/oradata/orcl/users01.dbf                    
                    
5                    
/home/oracle/app/oracle/oradata/orcl/example01.dbf                    
                    
6                    
/home/oracle/app/oracle/oradata/orcl/APEX_1930613455248703.dbf                    
                                        
     FILE#                    
----------                    
NAME                    
--------------------------------------------------------------------------------                    
7                    
/home/oracle/app/oracle/oradata/orcl/APEX_2041602962184952.dbf                    
                                        
7 rows selected.                                        
SQL>                
                    
SQL> alter system dump datafile 4 block 20927;                                        
System altered.                    
                    
SQL> select value from v$parameter where name='user_dump_dest';                    
                    
VALUE                    
--------------------------------------------------------------------------------                    
/home/oracle/app/oracle/diag/rdbms/orcl/orcl/trace                         
SQL>                     
                    
SQL>                     
SQL> select spid from v$session s, v$process p                    
  2    where p.addr = s.paddr                    
  3    and s.audsid = sys_context('userenv','sessionid');                    
                    
SPID                    
------------------------                    
3984                    
4042                                        
SQL>                    
复制代码

找到 /home/oracle/app/oracle/diag/rdbms/orcl/orcl/trace 下的 dump 文件:

vim orcl_ora_3984.trc,其末尾一段有:

复制代码
block_row_dump:    
tab 0, row 0, @0x1f90    
tl: 8 fb: --H-FL-- lb: 0x2  cc: 2    
col  0: [ 2]  c1 02    
col  1: [ 1]  64    
tab 0, row 1, @0x1f88    
tl: 8 fb: --H-FL-- lb: 0x0  cc: 2    
col  0: [ 2]  c1 03    
col  1: [ 1]  62    
tab 0, row 2, @0x1f80    
tl: 8 fb: --H-FL-- lb: 0x0  cc: 2    
col  0: [ 2]  c1 04    
col  1: [ 1]  63    
end_of_block_dump    
End dump data blocks tsn: 4 file#: 4 minblk 20927 maxblk 20927    
复制代码

64 就是 d 的 ascii 码,表明未提交数据也被刷到数据文件上了。

再来看事务状态:active  表示尚未提交。

复制代码
SQL> select xidusn,xidslot,xidsqn,ubafil,ubablk,status from v$transaction;                        
    XIDUSN    XIDSLOT     XIDSQN     UBAFIL     UBABLK STATUS                        
---------- ---------- ---------- ---------- ---------- ----------------                        
        10          8       9187          3       1334 ACTIVE                        
SQL>                         
                        
SQL> select * from testtab;                        
                        
        ID N                        
---------- -                        
         1 a                        
         2 b                        
         3 c                        
                        
SQL>                         
复制代码

然后回到session 2: 

SQL>  commit;                       

然后回到session 1,来看:这是就看到提交好的数据了。

复制代码
SQL> select dbms_rowid.rowid_relative_fno(rowid) as fno,dbms_rowid.rowid_block_number(rowid) block, t.* from testtab t;                                            
                                            
       FNO      BLOCK         ID N                                            
---------- ---------- ---------- -                                            
         4      20927          1 d                                            
         4      20927          2 b                                            
         4      20927          3 c                                            
复制代码

此时如果在dump 数据文件,得到的结果,可以看到 提交后的数据(name=d)在 dump 中。

事实上,数据文件中,对此table,只会维持一份拷贝。其他的要靠 undo 表空间的undo segment 来维持。

结束





本文转自健哥的数据花园博客园博客,原文链接:http://www.cnblogs.com/gaojian/archive/2012/11/13/2767620.html,如需转载请自行联系原作者

目录
相关文章
|
14天前
|
Oracle 关系型数据库 网络安全
Oracle 19c 安装教程学习
Oracle 19c 安装教程学习
40 2
|
2月前
|
Oracle 关系型数据库 数据库
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
打开oracle数据库报错“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。 数据库没有备份,无法通过备份去恢复数据库。用户方联系北亚企安数据恢复中心并提供Oracle_Home目录中的所有文件,急需恢复zxfg用户下的数据。 出现“system01.dbf需要更多的恢复来保持一致性”这个报错的原因可能是控制文件损坏、数据文件损坏,数据文件与控制文件的SCN不一致等。数据库恢复工程师对数据库文件进一步检测、分析后,发现sysaux01.dbf文件损坏,有坏块。 修复并启动数据库后仍然有许多查询报错,export和data pump工具使用报错。从数据库层面无法修复数据库。
数据库数据恢复—Oracle数据库文件出现坏块的数据恢复案例
|
19天前
|
Oracle 关系型数据库 数据库
oracle数据恢复—Oracle数据库文件损坏导致数据库打不开的数据恢复案例
打开oracle数据库时报错,报错信息:“system01.dbf需要更多的恢复来保持一致性,数据库无法打开”。急需恢复zxfg用户下的数据。 出现上述报错的原因有:控制文件损坏、数据文件损坏、数据文件与控制文件的SCN不一致等。数据恢复工程师对数据库文件做进一步检测分析后发现sysaux01.dbf文件有坏块。修复sysaux01.dbf文件,启动数据库依然有许多查询报错。export和data pump工具无法使用,查询告警日志并分析报错,确认发生上述错误的原因就是sysaux01.dbf文件损坏。由于该文件损坏,从数据库层面无法修复数据库。由于system和用户表空间的数据文件是正常的,
|
5月前
|
SQL Oracle 关系型数据库
mysql和oracle 命令行执行sql文件 数据库执行sql文件 执行sql语句
mysql和oracle 命令行执行sql文件 数据库执行sql文件 执行sql语句
70 0
|
5月前
|
存储 SQL Oracle
oracle 存储过程导出sql语句 导出为文件
oracle 存储过程导出sql语句 导出为文件
173 0
|
6月前
|
运维 Oracle 关系型数据库
Oracle日志文件:数据王国的“记事本”
【4月更文挑战第19天】Oracle日志文件是数据库稳定运行的关键,记录数据变更历史,用于恢复和故障处理。它们协调并发操作,确保数据一致性和完整性。日志文件实时写入操作信息并定期刷新到磁盘,便于数据恢复。然而,日志文件需备份和归档以保证安全性,防止数据丢失。日志文件,数据王国的“记事本”,默默守护数据安全。
|
6月前
|
运维 Oracle 安全
Oracle的三重奏:密码文件、警告文件与跟踪文件
【4月更文挑战第19天】Oracle数据库的三大守护者:密码文件保护系统免受未经授权访问,如同宝藏的“密码锁”;警告文件似“哨兵”,记录错误信息,助于及时解决问题;跟踪文件扮演“侦探”角色,详尽记录操作,便于性能优化和故障排查。这三份文件共同确保数据王国的安全与稳定。作为管理员,重视并善用它们是关键。
|
6月前
|
运维 Oracle 关系型数据库
Oracle服务器参数文件:数据王国的“调控大师”
【4月更文挑战第19天】Oracle服务器参数文件,数据库的“调控大师”,掌控着内存管理、进程调度等关键设置。通过参数调整如SGA_MAX_SIZE和PROCESSES,实现性能优化和故障防控。虽然挑战重重,但成功的性能调优带来无尽成就感。它在备份恢复中也扮演重要角色,保障数据一致性与可用性。成为真正的“调控大师”,为数据王国效力!
|
6月前
|
存储 Oracle 安全
Oracle控制文件:数据王国的导航仪
【4月更文挑战第19天】Oracle控制文件是数据库的关键组件,存储结构信息和元数据,用于数据库启动、恢复。它指引数据库找到所需文件,保证数据完整性。控制文件的多重备份和定期更新确保其安全可靠。作为数据库导航仪,它对管理员理解和维护数据库至关重要,为数据存储和恢复提供关键支持。
|
6月前
|
Oracle 关系型数据库 数据库
Oracle 11gR2学习之三(创建用户及表空间、修改字符集和Oracle开机启动)
Oracle 11gR2学习之三(创建用户及表空间、修改字符集和Oracle开机启动)

推荐镜像

更多