MySQL面试精华:40经典问题深度解析+全面技巧总结

0 下载量 27 浏览量 更新于2024-08-03 收藏 49KB DOCX 举报
MySQL作为关系型数据库管理系统(RDBMS)的重要组成部分,在面试中经常被提问,因为它广泛应用于web应用和企业级系统。以下是一些关键的MySQL知识点总结: 1. **数据库事务**:事务是一组操作的集合,这些操作要么全部成功,要么全部失败,确保数据的一致性。事务的四大特性包括原子性(Atomicity)、一致性(Consistency)、隔离性(Isolation)和持久性(Durability),也称为ACID特性。 2. **事务特性实现**:事务的隔离级别有不同等级,如读未提交(Read Uncommitted)、读已提交(Read Committed)、可重复读(Repeatable Read)和串行化(Serializable)。脏读、不可重复读和幻读分别指在不同隔离级别下可能遇到的问题:脏读看到未提交的更新,不可重复读在同一事务内两次查询结果不一致,幻读则是在一次事务中多次读取到新增的数据。 3. **MySQL数据类型**:`datetime`和`timestamp`都是日期时间类型,但`datetime`允许空值,而`timestamp`默认自动设置当前时间且不为空。`varchar`和`char`是字符串类型,主要区别在于`varchar`可变长度,`char`固定长度。 4. **SQL聚合函数**:`count(1)`计算行数,`count(*)`计算所有非NULL值的行数,而`count(列名)`只计算指定列的非NULL值。`exist`用于检查子查询是否有结果,`in`用于检查某个值是否在一组值中。 5. **数据操作**:`truncate`清空表数据但保留结构,`delete`逐行删除数据,`drop`彻底删除表。`union`合并两个或更多SELECT的结果集,`union all`包含所有行,包括重复的。 6. **数据分析**:`group by`对数据进行分组并汇总,`distinct`返回唯一的值。`Blob`和`text`都是二进制大对象类型,`Blob`通常用于存储二进制数据,`text`更通用,但大小受限。 7. **存储引擎**:MySQL常见的存储引擎有MyISAM、InnoDB、Memory等,MyISAM支持快速插入但不支持事务,InnoDB支持事务和行级锁定。 8. **日志管理**:`binlog`(二进制日志)记录更改操作,`redo log`(重做日志)用于InnoDB恢复,`undolog`(undo log)用于撤销操作。它们在事务回滚和主从复制中起关键作用。 9. **数据库设计**:遵循第三范式(消除冗余数据)、第四范式(消除多对多关系中的数据冗余)来提高数据的逻辑一致性。存储过程是预编译的SQL代码,优点包括安全性、可重用性和效率,但可能增加复杂性。 10. **性能优化**:在日常开发中,关注SQL查询效率,避免全表扫描,合理利用索引,减少JOIN操作,使用分区或分片技术。针对大数据量,采用批量删除、分区查询等策略。 11. **分库分表**:为应对数据增长和高并发,将数据分散到多个物理数据库(库)和表(表),根据业务需求和数据量设计合理的分片规则,解决单表过大导致的问题。分库分表会带来数据一致性、路由和数据迁移等挑战。 12. **主从复制**:主库写入数据,从库实时同步,延迟产生的原因可能包括网络、磁盘I/O、事务等待等,通过优化配置和监控来降低延迟。 13. **其他技术选型**:例如选择自增ID还是UUID作为主键,以及在大表查询、分布式架构和数据迁移时采用的工具和方法。 通过掌握这些知识点,面试者可以展现出扎实的MySQL技术基础和实践经验,对于实际工作中的问题解决能力也有显著提升。