SQL事务的运作方式
(这里面没有关于涉及内存方面的读写细则,关于涉及到内存读写细则的会在下一篇单独介绍的哈)一,事务开始
(1.1)所有DML语句必然是基于事务的,如果没有显式开启事务(SQL SERVER 默认不开启隐式事务,这点与Oracle正好相反),则事务处理的最小单位为每一条DML语句,即每条语句作为一个事务,并自动提交事务;
(1.2)除非手动开启一个事务(BEGIN TRAN),或开启隐式事务(SET IMPLICIT_TRANSACTIONS ON),才需要手动提交事务(COMMIT TRAN),否则SQL SERVER自动提交事务;二,发起DML(片尾有福利,主要涉及各个分类的控制语言与命令,朋友们可以可选性的LOOK哈。)
(2.1)DML语句包括:INSERT、DELETE、UPDATE;
(2.2)DDL语句最终是被转化为对系统表的DML,在SQL SERVER中DDL语句也可以被回滚(ORACLE不可以),比如:CREATE/ALTER/DROP/TRUNCATE,另外DCL语句也可以被回滚;三,数据是否在内存
(3.1)在内存中查找数据使用HASH算法,不多说;
(3.2)如果数据页不在内存中,则需要从磁盘上的数据文件中,读取相应的数据页到内存中,即物理读,以2.1的方式查找数据页(哪怕没找到),即逻辑读。四,修改数据
(4.1)在SQL SERVER内存的数据缓冲区中将数据页修改,此时数据页称为脏页(DIRTY PAGE);
(4.2)在SQL SERV