MySQL存储引擎
简介
MySQL可以将数据以不同的技术存储在文件(内存)中,这种技术就称为存储引擎。每一种存储引擎使用不同的存储机制,索引技巧,锁定水平,最终提供广泛且不同的功能。
并发控制
- 当多个连接对记录进行修改是保证数据的一致性和完整性
- 锁
- 共享锁(读锁):在同一时间段内,多个用户可以读取同一个资源,读取过程中数据不会发生任何变化
- 排它锁(写锁):在任何时候只能有一个用户写入资源,当进行写锁时会阻塞其他的读锁或者写锁操作
- 锁颗粒
- 表锁,是一种开销最小的锁策略
- 行锁,是一种开销最大的锁策略
事务处理
- 事务
- 事务用于保证数据库的完整性ACID操作
存储引擎
- MyISAM
- InnoDB
- Memory
- CSV
- Archive
设置表的存储引擎
修改存储引擎的方法
* 通过修改MySQL配置文件实现: - default-storage-engine = engine
* 通过创建数据表命令实现
CREATE TABLE table_name(
...
...
)ENGINE = engine;
- 通过修改数据表结构
ALTER TABLE tp1 ENGINE = InnoDB;