首页 > 数据库 > MySQL > 正文

MySQL数据库日常面试题有哪些

2024-07-24 12:33:07
字体:
来源:转载
供稿:网友
  本篇内容主要讲解“MySQL数据库常见面试题有哪些”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL数据库常见面试题有哪些”吧!
  
  1、数据库的常用范式:
  第一范式(1NF):指表的列不可再分,数据库中表的每一列都是不可分割的基本数据项,同一列中不能有多个值;
  第二范式(2NF):在 1NF 的基础上,还包含两部分的内容:一是表必须有一个主键;二是表中非主键列必须完全依赖于主键,不能只依赖于主键的一部分;
  第三范式(3NF):在 2NF 的基础上,消除非主键列对主键的传递依赖,非主键列必须直接依赖于主键。
  BC范式(BCNF):在 3NF 的基础上,消除主属性对于码部分的传递依赖
  2、SQL语句的执行过程:
  2.1、客户端的数据库驱动与数据库连接池:
 
  (1)客户端与数据库进行通信前,通过数据库驱动与MySQL建立连接,建立完成之后,就发送SQL语句
 
  (2)为了减少频繁创建和销毁连接造成系统性能的下降,通过数据库连接池维护一定数量的连接线程,当需要进行连接时,就直接从连接池中获取,使用完毕之后,再归还给连接池。常见的数据库连接池有 Druid、C3P0、DBCP
 
  2.2、MySQL架构的Server层的执行过程:
 
  (1)连接器:主要负责跟客户端建立连接、获取权限、维持和管理连接
 
  (2) 执行器:根据一系列的执行计划去调用存储引擎提供的API接口去调用操作数据,完成SQL的执行。
 
  2.3、Innodb存储引擎的执行过程:
 
  (1)首先MySQL执行器根据 执行计划 调用存储引擎的API查询数据
  (2)存储引擎先从缓存池buffer pool中查询数据,如果没有就会去磁盘中查询,如果查询到了就将其放到缓存池中
  (3)在数据加载到 Buffer Pool 的同时,会将这条数据的原始记录保存到 undo 日志文件中
  (4)innodb 会在 Buffer Pool 中执行更新操作
  (5)更新后的数据会记录在 redo log buffer 中
  (6)提交事务在提交的同时会做以下三件事
  (7)(第一件事)将redo log buffer中的数据刷入到redo log文件中
  (8)(第二件事)将本次操作记录写入到 bin log文件中
  (9)(第三件事)将bin log文件名字和更新内容在 bin log 中的位置记录到redo log中,同时在 redo log 最后添加 commit 标记
  (10)使用一个后台线程,它会在某个时机将我们Buffer Pool中的更新后的数据刷到 MySQL 数据库中,这样就将内存和数据库的数据保持统一了
  3、常用的存储引擎?InnoDB与MyISAM的区别?
  存储引擎是对底层物理数据执行实际操作的组件,为Server服务层提供各种操作数据的API。常用的存储引擎有InnoDB、MyISAM、Memory。这里我们主要介绍InnoDB 与 MyISAM 的区别:
 
  (1)事务:MyISAM不支持事务,InnoDB支持事务
 
  (2)锁级别:MyISAM只支持表级锁,InnoDB支持行级锁和表级锁,默认使用行级锁,但是行锁只有通过索引查询数据才会使用,否则将使用表锁。行级锁在每次获取锁和释放锁的操作需要消耗比表锁更多的资源。使用行锁可能会存在死锁的情况,但是表级锁不存在死锁
 
  (3)主键和外键:MyISAM 允许没有任何索引和主键的表存在,不支持外键。InnoDB的主键不能为空且支持主键自增长,如果没有设定主键或者非空唯一索引,就会自动生成一个6字节的主键,支持外键完整性约束
 
  (4)索引结构:MyISAM 和 InnoDB 都是使用B+树索引,MyISAM的主键索引和辅助索引的Data域都是保存行数据记录的地址。但是InnoDB的主键索引的Data域保存的不是行数据记录的地址,而是保存该行的所有数据内容,而辅助索引的Data域保存的则是主索引的值。

(编辑:武林网)

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表