日期:2014-05-16 浏览次数:20471 次
存储引擎(Storage Engine)
MySQL 有一个重要特征,即:可替换存储引擎构架(Pluggable Storage Engine Architecture)
MySQL 的功能分为 2 个部分,
外层部分:负责完成与客户端的连接、对 SQL 语句进行事前检查等。
内层部分:存储引擎部分,负责接收外层的数据操作指示,完成实际的数据输入输出以及文件操作。
MySQL 提供了多种存储引擎,用户可自由选择(也可以给不同的表,选择不同的存储引擎)
用户可以任意选择存储引擎,这是 MySQL 独有的特征。
MyISAM :默认的高速引擎,不支持事务处理
InnoDB :支持行锁定,以及事务处理,比
MyISAM 的处理速度稍慢
ISAM :MyISAM 引擎的前身。MySQL 5.0 以后,不再标准安装
MERGE : 该引擎,会将多个 MyISAM 类型的表,作为一个表来处理
MEMORY, HEAP : 只在内存上保存数据
Falcon :一种新的存储引擎,支持事务处理
ARCHIVE: 将数据压缩后保存 (只能进行 INSERT / SELECT 操作)
CSV : 以CSV 形式保存数据(应用于跨平台数据交换)
my.ini 中, 设置:default-storage-engine=INNODB
才能使用 InnoDB 引擎,来支持事务处理
SHOW CREATE TABLE customer; SHOW CREATE TABLE customer\G
ALTER TABLE customer ENGINE=MyISAM;
BEGIN; -- 或者 START TRANSACTION DELETE FROM customer; SELECT * FROM customer; ROLLBACK;
SELECT @@AUTOCOMMIT; SET AUTOCOMMIT=0; --关闭自动提交功能 SELECT * FROM customer; DELETE FROM customer; ROLLBACK; -- 关闭自动提交,无需 BEGIN 操作,也能使用 ROLLBACK /* 这种情况下,如果不执行 COMMIT 操作,则所有更新不会反映到数据库中 */
BEGIN; INSERT INTO customer VALUES('T0001', '王二', '1980-10-21', 1); SAVEPOINT sp; INSERT INTO customer VALUES('T0002', '田三', '1985-10-21', 1); SELECT * FROM customer; ROLLBACK TO SAVEPOINT sp; SELECT * FROM customer; ROLLBACK; SELECT * FROM customer;
DROP DATABASE; DROP TABLE; DROP; ALTER TABLE;
锁定粒度:记录(行)、表、数据库。
锁定提升机制:当行单位粒度的锁定,大量产生时,数据库将锁定粒度自动向上提升(比如,提升成表粒度的锁定,或者数据库粒度的锁定)
分离水平:事务处理之间的影响程度(同时运行时互相影响的机制)
分离水平有 4 种:
READ UNCOMMITTED :支持, 非提交读取、不可重复读取、幻象读取
READ COMMITTED :支持,不可重复读取、幻象读取
REPEATABLE READ :支持,幻象读取
SERIALIZABLE :都不支持
非提交读取(脏读 Dirty Read):能从别的事务处理中,读取到尚未提交的更新数据,只发生在 READ UNCOMMITTED 分离水平。不推荐使用
SET SESSION TRANSACTION ISOLATION LEVEL READ UNCOMMITTED;