面试必背-MySql八股文(1)

1.数据库三大范式

  • 第一范式:确保每列保持原子性,数据表中的所有字段值都是不可分解的原子值。

  • 第二范式:确保表中的每列都和主键相关。

  • 第三范式:确保每列都和主键列直接相关而不是间接相关。

2. MySql几种引擎,有什么区别

特性 InnoDB MyISAM MEMORY
事物安全 支持 不支持 不支持
对外建的支持 支持 不支持 不支持
存储限制 64TB
空间使用
内存使用
插入数据的速度

2.1、 InnoDB、MyISAM 对比

  • InnoDB支持事务,MyISAM不支持。

  • InnoDB 支持外键,而 MyISAM 不支持。

  • InnoDB是聚集索引,数据文件是和索引绑在一起的,必须要有主键。MyISAM是非聚集索引,索引和数据文件是分离的,索引保存的是数据文件的指针。主键索引和辅助索引是独立的。

  • InnoDB 不保存表的具体行数。MyISAM 用一个变量保存了整个表的行数。

  • Innodb 有 redolog 日志文件,MyISAM 没有。

  • Innodb存储文件有frm、ibd,而Myisam是frm、MYD、MYI。

  • Innodb:frm是表定义文件,ibd是数据文件。

  • Myisam:frm是表定义文件,myd是数据文件,myi是索引文件。

  • InnoDB 支持表、行锁,而 MyISAM 支持表级锁。

  • InnoDB 必须有唯一索引(主键),如果没有指定的话 InnoDB 会自己生成一个隐藏列 Row_id 来充当默认主键,MyISAM 可以没有。

3. 为什么要使用自增主键?

1.普通索引的 B+ 树上存放的是主键索引的值,如果该值较大,会「导致普通索引的存储空间较大」

2.使用自增 id 做主键索引新插入数据只要放在该页的最尾端就可以,直接「按照顺序插入」,不用刻意维护

3.页分裂容易维护,当插入数据的当前页快满时,会发生页分裂的现象ÿ

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
面试官提出关于MySQL的问题时,你可以参考以下八股文回答: 1. MySQL是什么?有哪些特点? MySQL是一种开源的关系型数据库管理系统,具有以下特点:可靠性高、性能优秀、易于使用、跨平台、支持多种编程语言等。 2. 什么是数据库事务? 数据库事务是由一系列数据库操作组成的逻辑单位,它要么全部执行成功,要么全部失败回滚,以保证数据的一致性和完整性。 3. 请解释ACID是什么意思? ACID是数据库事务的四个特性: - 原子性(Atomicity):事务中的所有操作要么全部成功执行,要么全部回滚。 - 一致性(Consistency):事务执行前后,数据库从一个一致性状态转换到另一个一致性状态。 - 隔离性(Isolation):事务之间互不干扰,每个事务都感觉不到其他事务的存在。 - 持久性(Durability):事务成功提交后,对数据的修改将永久保存在数据库中。 4. 请解释索引在MySQL中的作用? 索引是一种数据结构,用于加速数据库的查询操作。它可以提高数据检索的效率,减少数据库的IO操作。 5. 请解释什么是主键、外键和唯一键? - 主键(Primary Key):用于唯一标识表中的每一行数据,不允许重复和NULL值。 - 外键(Foreign Key):用于建立表与表之间的关系,指向其他表的主键。 - 唯一键(Unique Key):保证该列的值在表中是唯一的,允许NULL值。 6. 请解释什么是数据库的范式? 数据库的范式是设计数据库时遵循的一组规范,用来减少冗余数据并提高数据的完整性。常见的范式有1NF、2NF、3NF等。 7. 请解释什么是数据库的连接(Join)操作? 连接操作用于将多个表中相关联的数据进行组合查询。常见的连接操作有内连接、外连接和交叉连接。 8. 请解释什么是数据库的备份和恢复? 数据库备份是指将数据库的数据和结构以某种方式复制到其他介质上,以便在数据丢失或损坏时进行恢复。数据库恢复是指在数据丢失或损坏后,通过备份文件中的数据恢复到原始状态。 以上是MySQL面试八股文的常见问题和回答。在面试中,除了准备这些基础知识外,还应该根据实际经验和项目经历进行深入的思考和回答。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱笑的tiger

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值