Bootstrap

MySQL 面试突击指南:核心知识点解析1

MySQL中有哪些存储引擎?

请添加图片描述

InnoDB存储引擎

InnoDB是MySQL的默认事务型引擎,也是最重要、使用最广泛的存储引擎,设计用于处理大量短期事务。

MyISAM存储引擎

在MySQL 5.1及之前版本,MyISAM是默认的存储引擎。它提供了全文索引、压缩、空间函数(GIS)等特性,但不支持事务和行级锁,崩溃后无法安全恢复。

Merge存储引擎

Merge存储引擎将多个MyISAM表聚合在一起,便于进行统一查询、删除和更新操作,但其内部并不保存数据,数据依旧在MyISAM表中。

Archive存储引擎

Archive存储引擎仅支持INSERT和SELECT操作,插入的行会被压缩,适合日志和数据采集类应用,但查询时需要执行全表扫描。

Blackhole存储引擎

Blackhole引擎不保存任何插入的数据,可以在某些特殊的复制架构和日志审核时使用。

CSV存储引擎

CSV引擎将普通的CSV文件作为MySQL的表来处理,但不支持索引,适合作为数据交换机制。

Federated存储引擎

Federated引擎是访问其他MySQL服务器的代理,创建到远程MySQL服务器的客户端连接,将查询传输到远程服务器执行。

Memory存储引擎

Memory表的数据文件存储在内存中,适用于查找表、缓存周期性聚合数据和保存数据分析中的中间数据。

NDB集群引擎

MySQL Cluster结合MySQL服务器和NDB集群存储引擎,提供分布式、高可用的数据库解决方案。

数据库表设计时,如何选择字段类型?

  • 使用最小数据类型:更小的数据类型通常更快,占用更少的磁盘、内存和CPU缓存。
  • 简单数据类型:简单数据类型操作需要更少的CPU周期,如使用整数代替字符串来存储日期和时间。
  • 避免NULL</
;