事务开始
(0.1)所有DML语句必然是基于事务的,如果没有显式开启事务(SQL SERVER 默认不开启隐式事务,这点与ORACLE正好相反),则事务处理的最小单位为每一条DML语句,即每条语句作为一个事务,并自动提交事务;
(0.2)除非手动开启一个事务(BEGIN TRAN),或开启隐式事务(SET IMPLICIT_TRANSACTIONS ON),才需要手动提交事务(COMMIT TRAN),否则SQL SERVER自动提交事务;
(1)发起DML
(1.1)DML语句包括:INSERT、DELETE、UPDATE;
(1.2)DDL语句最终是被转化为对系统表的DML,在SQL SERVER中DDL语句也可以孝袭渗被回滚(ORACLE不可以),比如:CREATE/ALTER/DROP/TRUNCATE,另外DCL语句也可以被回滚;
(2)数据是否在内存
(2.1)在内存中查找数据使用HASH算法,不多说;
(2.2)如果数据页不在内存中,则巧脊需要从磁盘上的数据文件中,读取相应的数据页到内存中,即物理读,以2.1的方式查找数据页(哪怕没找到),即逻辑读。
(3)修改数据
(3.1)在SQL SERVER内存的数据缓冲区中将数据页修改,此时数据页称为脏页(DIRTY PAGE);
(3.2)在SQL SERVER 内存的日志缓禅虚冲区中记录REDO LOG,姑且称为脏日志;
(4)事务结束
(4.1)提交(COMMIT),此时将当前事务的脏日志刷新到数据库的日志文件中,并打上事务结束标记(COMMIT),脏页有可能暂未被刷新到数据文件;