1、MySQL 中有哪几种锁?
1、表级锁: 开销小, 加锁快; 不会出现死锁; 锁定粒度大, 发生锁冲突的概率最高, 并发度最低。
2、行级锁: 开销大, 加锁慢; 会出现死锁; 锁定粒度最小, 发生锁冲突的概率最低, 并发度也最
高。
3、页面锁: 开销和加锁时间界于表锁和行锁之间; 会出现死锁; 锁定粒度界于表锁和行锁之间, 并
发度一般。
2、MySQL 中有哪些不同的表格?
共有 5 种类型的表格: 1、MyISAM2、Heap 3、Merge 4、INNODB 5、MISAM
3、简述在MySQL 数据库中 MyISAM 和InnoDB 的区别
MyISAM:
不支持事务, 但是每次查询都是原子的; 支持表级锁, 即每次操作是对整个表加锁; 存储表的总行
数;
一个 MYISAM 表有三个文件: 索引文件、表结构文件、数据文件;
采用菲聚集索引, 索引文件的数据域存储指向数据文件的指针。辅索引与主索引基本一致, 但是辅索
引不用保证唯一性。
InnoDb:
支持 ACID 的事务, 支持事务的四种隔离级别; 支持行级锁及外键约束: 因此可以支持写并发; 不存
储总行数:
一个 InnoDb 引擎存储在一个文件空间( 共享表空间, 表大小不受操作系统控制,
一个表可能分布在多个文件里), 也有可能为多个( 设置为独立表空, 表大小受操作系统文件大小限
制, 一般为 2G), 受操作系统文件大小的限制;