MySQL面试60题和答案详解

版权申诉
0 下载量 191 浏览量 更新于2024-07-03 收藏 1.64MB PDF 举报
MySQL面试60题和答案 MySQL是一种流行的开源关系数据库管理系统,广泛应用于各种Web应用程序中。以下是 MySQL 面试60题和答案中的一些重要知识点: **锁机制** 在 MySQL 中,有三种锁机制:表级锁、行级锁和页面锁。 * 表级锁:开销小,加锁快;不会出现死锁;锁定粒度大,发生锁冲突的概率最高,并发度最低。 * 行级锁:开销大,加锁慢;会出现死锁;锁定粒度最小,发生锁冲突的概率最低,并发度也最高。 * 页面锁:开销和加锁时间界于表锁和行锁之间;会出现死锁;锁定粒度界于表锁和行锁之间,并发度一般。 **表类型** MySQL 中有五种类型的表格: 1. MyISAM 2. Heap 3. Merge 4. INNODB 5. ISAM **MyISAM 和 InnoDB 的区别** MyISAM 和 InnoDB 是 MySQL 中两种最常用的存储引擎。 * MyISAM: + 不支持事务,但是每次查询都是原子的; + 支持表级锁,即每次操作是对整个表加锁; + 存储表的总行数; + 一个 MYISAM 表有三个文件:索引文件、表结构文件、数据文件; + 采用菲聚集索引,索引文件的数据域存储指向数据文件的指针。 * InnoDB: + 支持 ACID 事务,支持事务的四种隔离级别; + 支持行级锁及外键约束:因此可以支持写并发; + 不存储总行数; + 一个 InnoDb 引擎存储在一个文件空间(共享表空间,表大小不受操作系统控制,一个表可能分布在多个文件里),也有可能为多个(设置为独立表空,表大小受操作系统文件大小限制,一般为 2G),受操作系统文件大小的限制; + 主键索引采用聚集索引(索引的数据域存储数据文件本身),辅索引的数据域存储主键的值。 **事务隔离级别** MySQL 中 InnoDB 支持的四种事务隔离级别为: 1. read uncommitted:读到未提交数据 2. read committed:脏读,不可重复读 3. repeatable read:可重读 4. serializable:串行事物 **CHAR 和 VARCHAR 的区别** CHAR 和 VARCHAR 是两种字符串类型,但是它们在存储和检索方面有所不同: * CHAR 列长度固定为创建表时声明的长度,长度值范围是 1 到 255。 * 当 CHAR 值被存储时,它们被用空格填充到特定长度,检索 CHAR 值时需删除尾随空格。 **主键和候选键** * 主键:表格的每一行都由主键唯一标识,一个表只有一个主键。 * 候选键:候选键是可以唯一标识表格每一行的列或列组合,但是一个表可以有多个候选键。