首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 数据库 > 其他数据库 >

事务处理及锁定 【数据库高效率编程 - 学习笔记 第六章】

2012-11-26 
事务处理及锁定 【数据库高效编程 - 学习笔记 第六章】事务处理(Transaction)是将多个更新命令作为一个整体

事务处理及锁定 【数据库高效编程 - 学习笔记 第六章】
事务处理(Transaction)是将多个更新命令作为一个整体来执行,从而保证数据整合性的机制。


存储引擎(Storage Engine
MySQL 有一个重要特征,即:可替换存储引擎构架(Pluggable Storage Engine Architecture
MySQL 的功能分为 2 个部分,
外层部分:负责完成与客户端的连接、对 SQL 语句进行事前检查等。
内层部分:存储引擎部分,负责接收外层的数据操作指示,完成实际的数据输入输出以及文件操作。

MySQL 提供了多种存储引擎,用户可自由选择(也可以给不同的表,选择不同的存储引擎)
用户可以任意选择存储引擎,这是 MySQL 独有的特征。

MyISAM :默认的高速引擎,不支持事务处理
InnoDB :支持行锁定,以及事务处理,比 MyISAM 的处理速度稍慢
ISAMMyISAM 引擎的前身。MySQL 5.0 以后,不再标准安装
MERGE : 该引擎,会将多个 MyISAM 类型的表,作为一个表来处理
MEMORYHEAP : 只在内存上保存数据
Falcon :一种新的存储引擎,支持事务处理
ARCHIVE: 将数据压缩后保存 (只能进行 INSERT / SELECT 操作)
CSV : 以CSV 形式保存数据(应用于跨平台数据交换)


my.ini 中, 设置:default-storage-engine=INNODB
才能使用 InnoDB 引擎,来支持事务处理

SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;

不可重复读取(Non-Repeatable Read):某一事务处理中,由于其他事务处理的更新操作,导致,对同一数据的多次读取,结果不同。
发生在 READ COMMITED 以下的分离水平

幻象读取(Phantom Read):某一事务处理中,对同一数据进行多次读取时,由于其他事务处理的插入、删除操作,
使得结果中,出现了第一读取时,不存在的数据,或者,第一次读取时,存在的数据消失了,的现象。


死锁(Dead Lock)两个不同的事务处理,在相互等待对方释放锁定,永远也不可能解除锁定的一种状态。

事务处理的机制,简单的说,就是,留下更新日志。
与事务处理相关的日志,分为2个类型:UNDO 日志、 REDO 日志

UNDO 日志,又称:回滚段(Rollback Segment
REDO 日志,又称:事务处理日志、或 日志。

热点排行