(这里面没有关于涉及内存方面的读写细则,关于涉及到内存读写细则的会在下一篇单独介绍的哈)
(1.1)所有DML语句必然是基于事务的,如果没有显式开启事务(SQL SERVER 默认不开启隐式事务,这点与Oracle正好相反),则事务处理的最小单位为每一条DML语句,即每条语句作为一个事务,并自动提交事务; (1.2)除非手动开启一个事务(BEGIN TRAN),或开启隐式事务(SET IMPLICIT_TRANSACTIONS ON),才需要手动提交事务(COMMIT TRAN),否则SQL SERVER自动提交事务;
(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 SERVER 内存的日志缓冲区中记录REDO LOG,姑且称为脏日志;
(5.1)提交(COMMIT),此时将当前事务的脏日志刷新到数据库的日志文件中,并打上事务结束标记(COMMIT),脏页有可能暂未被刷新到数据文件; 事务日志结构如下: BEGIN TRAN DML COMMIT TRAN (5.2)回滚(ROLLBACK),此时读REDO LOG(当中包括逻辑操作、或数据前后像)得到反向DML操作,反向修改脏页,将DML+反向DML从日志缓冲区刷新到数据库的日志文件中,并打上事务结束标记(ROLLBACK),同样,脏页有可能暂未被刷新到数据文件; 事务日志结构如下: BEGIN TRAN DML 反向DML ROLLBACK TRAN 不难发现,SQL SERVER的日志容易成为一个瓶颈(BOTTLENECK),因为在写的同时引入了读,即引入了竞争,而ORACLE用UNDO SEGMENT很好地避免了这个问题,REDO LOG永远只是在被串行写。
(6.1)从步骤4可以看出数据库的预写日志(WAL)原则,因为关系型数据库是基于事务的,而日志正是事务ACID属性的保证,也是数据恢复的保证; (6.2)检查点(CHECKPOINT),检查点周期性地将脏页刷新到数据文件中,在此之前,也是先将脏日志刷新到日志文件中,最终在日志文件打上检查点标记(CHECKPOINT),至此上面事务中修改的数据被正式写到磁盘上的数据文件中。 福利:(其实应该是备注更加恰当。哈。)
数据查询语言DQL用于检索数据库 基本结构是由SELECT子句,FROM子句,WHERE子句组成的查询块: SELECT 字段名表> FROM 表或视图名> WHERE 查询条件>
数据操纵语言DML用于改变数据库数据 主要有三种形式: 1) 插入:INSERT 2) 更新:UPDATE 3) 删除:DELETE
事务控制语言TCL用于维护数据的一致性 包含三条语句: 1)COMMIT; 2)ROLLBACK; 3)SAVEPOINT;
数据定义语言DDL用于建立,修改,删除数据库中的各种对象-----表、视图、 索引、同义词、聚簇等如: CREATE TABLE/VIEW/INDEX/SYN/CLUSTER | | | | | 表 视图 索引 同义词 簇
数据控制语言DCL用来授予或回收访问数据库的某种特权,并控制 数据库操纵事务发生的时间及效果,对数据库实行监视等。 包含两条命令: 1) GRANT:授权。 2)REVOKE:撤回。 PS:1) ROLLBACK [WORK] TO [SAVEPOINT]:回退到某一点。 回滚---ROLLBACK 回滚命令使数据库状态回到上次最后提交的状态。其格式为: SQL>ROLLBACK; 2) COMMIT [WORK]:提交。 在数据库的插入、删除和修改操作时,只有当事务在提交到数据 库时才算完成。在事务提交前,只有操作数据库的这个人才能有权看 到所做的事情,别人只有在最后提交完成后才可以看到。 提交数据有三种类型:显式提交、隐式提交及自动提交。下面分别说明这三种类型。(1) 显式提交 用COMMIT命令直接完成的提交为显式提交。其格式为: SQL>COMMIT; (2) 隐式提交 用SQL命令间接完成的提交为隐式提交。这些命令是: ALTER,AUDIT,COMMENT,CONNECT,CREATE,DISCONNECT,DROP, EXIT,GRANT,NOAUDIT,QUIT,REVOKE,RENAME。 (3) 自动提交 若把AUTOCOMMIT设置为ON,则在插入、修改、删除语句执行后, 系统将自动进行提交,这就是自动提交。其格式为: SQL>SET AUTOCOMMIT ON;
|
|