Oracle10gR2新特性:Asynchronous COMMIT
对于Oracle的commit机制,相信大家都已经非常的熟悉了。Oracle对于commit采取了同步写事务log的方式,也就是说,一旦发出commit命令,那么必须等待事务相关的所有redo都已经从 log buffer写出到redo logfile以后,才会控制权返回发出commit的进程。
同步commit有两个特点:
1.Immediate,发出commit命令后,立即将redo写出
2.Wait,在redo写出过程中,必须等待
但是,Oracle10gR2开始,一种新的commit机制被引入,这就是异步commit机制。也就是说,不必等到事务相关redo写出就可以返回了,异步commit也有两种特点:
1.Nowait,发出commit命令后,不关redo是否写出,立即返回控制权
2.Batch,redo的写出可以想buffer一样执行批量写出,以提高性能
当然,同步commit也可以batch,异步commit也可以将redo立即写出,所以上述四个特性可以自由组合。
本栏目更多精彩内容:http://www.bianceng.cnhttp://www.bianceng.cn/database/Oracle/
这样,commit引入了新的语法:
COMMIT [WRITE [IMMEDIATE | BATCH] [WAIT | NOWAIT] ]
默认情况下,commit的机制和以前一样,也就是相当于
COMMIT WRITE IMMEDIATE WAIT;
当然,这个默认机制可以通过初始化参数修改,所以Oracle10gR2又引入了一个新的参数COMMIT_WRITE,可能的取值包括
COMMIT_WRITE='{ IMMEDIATE | BATCH } , { WAIT | NOWAIT }'
异步commit由于不能确保事务的redo已经写出到redo logfile当中,一旦实例崩溃,可能导致已经commit的事务无法恢复,使用该特性的时候需要慎重考虑。
51cto博客 Oracle小混子