1,什么是mysql存储引擎?
mysql可以将数据已不同的技术存储在文件(内存)中,这种技术称为存储引擎。
每一种存储引擎使用不同的存储机制,索引技巧及锁定水平,最终提供广泛且不同的功能。
myql支持的存储引擎:
1. MyISAM
2. InnoDB
3. Memory
4. CSV
5. Archive
2,每种存储引擎特点
2.1 并发控制
- 并发控制:当多个连接对记录进行修改时保持数据的一致性和完整性。
- 锁:
- 共享锁(读锁),在同一时间段内,多个用户可以读取同一资源,读取过程中数据不会发生任何变化。
- 排他锁(写锁),在任何时候只能有一个用户写入资源,当进行写锁时会阻塞其他的读锁或者写锁的操作
- 锁颗粒
- 表锁,是一种开销最小的锁策略
- 行锁,是一种开销最大的锁策略
2.2 事务处理
事务用于保证数据库数据的完整性
2.3 外键
保证数据一致性的策略
2.4 索引
对数据表中一列或多列进行排序的一种结构,使用索引可以快速访问数据表中的特定信息
2.5 特点表
特点 | MyISAM | InnoDB | Memory | Archive |
---|---|---|---|---|
存储限制 | 256TB | 64TB | 有 | 无 |
事务 | - | 支持 | - | - |
支持索引 | 支持 | 支持 | 支持 | - |
锁粒度 | 表 | 行 | 表 | 行 |
数据压缩 | 支持 | - | - | 支持 |
外键 | - | 支持 | - | - |