oracle数据库写入数据的过程
来源:互联网 发布:python sum axis 1 编辑:程序博客网 时间:2024/06/09 02:53
各种后台进程的作用:
Ckpt、lgwr、dbwn之间的协作。
Ckpt:每隔3秒或更频繁写一次,写入控制文件,记录DBWN从SGA写入磁盘的块的位置。
LGWR:每3秒,1/3满buffer,commit,DBWN写之前。将buffer中数据写入物理文件。
DBWN:将SGA中脏块写入datafile。
Oracle 写入数据过程:
Oracle 写数据过程:dml操作一执行,首先在redo buffer中记录语句,在buffer cache中执行更改,修改数据块。然后LGWR进程根据上述规则,将redo buffer中的信息写入到物理文件。此过程比较快(redo log为连续写)。完成后,DBWN会将buffer cache中脏数据块对应的原始数据,复制到undo表空间,然后更新数据。(随机写,比较慢)。期间ckpt进程根据3秒的原则,作检查点,记录哪些脏 数据库写到了data file中(这里的检查点为增量检查点,并不是完全将脏数据写完,只是在控制文件中记录写到哪里了。)。将需要的信息记录在控制文件中。若实例崩溃或需要 错误恢复,从检查点位置以后的redo需要重新应用到datafile(常说的redo过程,前滚)。此时根据事务是否提交了,未提交的事务,根据 undo表空间的数据进行恢复(常说的undo,后滚操作)
另一位网友的介绍:
1、事务开始;
2、在buffer cache中找到需要的数据块,如果没有找到,则从数据文件中载入buffer cache中;
3、事务修改buffer cache的数据块,该数据被标识为“脏数据”,并被写入log buffer中;
4、事务提交,LGWR进程将log buffer中的“脏数据”写入redo log file中;
5、当发生checkpoint,CKPT进程更新所有数据文件的文件头中的信息,DBWn进程则负责将Buffer Cache中的脏数据写入到数据文件中。
附:checkpoint 由ckpt进程触发oracle进行checkpoint动作,将data buffer中的脏块(已经写在redo里记录但是没有写到datafile里的)的内容写入到data file里并释放站用的空间,由dbw后台进程完成,并修改controlfile和datafile的scn.
一般手工执行(alter system checkpoint)是由于要删除某个日志但是该日志里还有没有同步到data file里的内容,就需要手工check point来同步数据,然后就可以drop logfile group n.
- oracle数据库写入数据的过程
- HBase写入数据的过程
- HDFS的数据写入过程
- oracle数据库恢复数据过程
- 数据写入磁盘的过程,咔咔的!
- Nutch2 WebPage写入数据库的过程分析
- elasticsearch写入数据存储的过程
- shell脚本连接oracle数据库并将查询出的数据写入文件
- Oracle空间数据库的读取与写入
- Oracle空间数据库的读取与写入
- 一次oracle数据库数据块损坏的处理过程
- 一次较为完整的oracle数据库数据迁移过程
- 数据存储过程之MySQL与ORACLE数据库的差别
- 数据存储过程之MySQL与ORACLE数据库的差别
- DataTable的数据批量写入数据库
- DataTable的数据批量写入数据库
- DataTable的数据批量写入数据库
- android 大量数据写入数据库的优化
- Linux系统虚拟机的安装原理
- 普通工厂模式and抽象工厂模式
- Java的安全组成
- Ⅴ vue2.0 项目实战
- 实验二——双向链表
- oracle数据库写入数据的过程
- 【CodeForces
- 讲解基本自然语言处理NLP
- Apache Maven Assembly插件详解
- c primer plus 第十一章学习小结
- springmvc异常StandardWrapper.Throwable
- map中[]运算符和find的区别
- Map集合
- Java8 新特性之Stream----java.util.stream