【IT邦德MySQL面试宝典】-基础篇

IT邦德
大数据领域优质创作者
博客专家认证
2022-04-07 11:43:43

🚀 1.请简述MySQL数据库的优点?
Mysql 是开源的,所以你不需要支付额外的费用。
Mysql 支持大型的数据库,可以处理拥有上千万条记录的大型数据库。
MySQL 使用标准的 SQL 数据语言形式。
Mysql 可以允许于多个系统上,并且支持多种语言。
Mysql 对 PHP 有很好的支持,PHP 是目前最流行的 Web 开发语言。
MySQL 支持大型数据库,支持 5000 万条记录的数据仓库。
Mysql 是可以定制的,采用了 GPL 协议,你可以修改源码来开发自己的 Mysql 系统。

🚀 2.说一说三个范式
第一范式(1NF):
数据库表中的字段都是单一属性的,不可再分。
这个单一属性由基本类型构成,包括整型、实数、字符型、逻辑型、日期型等。
第二范式(2NF):
在第一范式的基础上,非主键列完全依赖于主键,而不能是依赖于主键的一部分
第三范式(3NF):
在第二范式的基础上,非主键列只依赖于主键,不依赖于其他非主键
总结:
在设计数据库结构的时候,要尽量遵守三范式,如果不遵守,必须有足够的理由。

🚀 3.事务的四大特性(ACID)介绍一下?
原子性(atomicity,或称不可分割性):事务的所有操作要么全部成功,要么全部回滚。
一致性(consistency):总是从一个一致性的状态转换到另一个一致性的状态
隔离性(isolation):多个事务并发执行时,一个事务的执行不应影响其他事务的执行
持久性(durability):已被提交的事务对数据库的修改应该永久保存在数据库中。

 

4.在 Linux 下安装MySQL有哪几种方式?
RPM (Redhat Package Manage):
安装简单,适合初学者学习使用,一台服务器只能安装一个 MySQL
二进制( Binary Package):
安装简单;可以安装到任何路径下,灵活性好;一台服务器可以安装多个 MySQL
源码( Source Package):
在实际安装的操作系统进行可根据需,要定制编译,最灵活;性能最好;服务器安装多个Source Code

🚀 5.为什么升级 MySQL,升级前注意事项?
为什么升级MySQL
1.基于安全考虑
2.基于性能和稳定性考虑:mgr 复制 ,并行复制 writeset 等功能,性能提升
3.新的功能:Hash join ,窗口函数,DDL 即时,json 支持
4.原始环境中版本太多,统一版本
5.8.0 版本基本已到稳定期,可以大量投入生产环境中

升级前注意事项
1.注意字符集设置:
>为了避免新旧对象字符集不一致的情况,在配置文件将字符集和校验规则设置为旧版本的字符集和比较规则。
2.密码认证插件变更:
为了避免连接问题,可以仍采用 5.7 的 mysql_native_password 认证插件。* 
3.sql_mode 支持问题: 
8.0 版本 sql_mode 不支持 NO_AUTO_CREATE_USER,要避免配置的 sql_mode 中带有NO_AUTO_CREATE_USER。* 
4.是否需要手动升级系统表:</font> 
在 MySQL 8.0.16 行 版本之前,需要手动的执行 mysql_upgrade 在 来完成该步骤的升级,在 MySQL8.0.16 版本及之后是由 mysqld 来完成该步骤的升级。
5.高可用架构:
 需要先升级从库,再逐步升级主库

🚀 6.存储引擎如何选择?
如果没有特别的需求,使用默认的Innodb即可。
InnoDB 引擎由于其对事务参照完整性,以及更高的并发性等优点开始逐步的取代 MyISAM
MyISAM:
以读写插入为主的应用程序,比如博客系统、新闻门户网站。
更新(删除)操作频率也高,或者要保证数据的完整性,并发量高,支持事务和外键,比如OA自动化办公系统,

如下是InnoDB引擎的4大特点
1.插入缓冲(insert buffer)
2.二次写(double write)
3.自适应哈希索引(ahi)
4.预读(read ahead)

🚀 7.事务隔离级别有哪些?
为了达到事务的四大特性,数据库定义了4种不同的事务隔离级别,
由低到高依次为Read uncommitted、Read committed、Repeatable read、Serializable,
>这四个级别可以逐个解决脏读、不可重复读、幻读这几类问题。
1.READ-UNCOMMITTED(读取未提交):
 最低的隔离级别,允许读取尚未提交的数据变更,可能会导致脏读、幻读或不可重复读。 
 2.READ-COMMITTED(读取已提交):
  允许读取并发事务已经提交的数据,可以阻止脏读,但是幻读或不可重复读仍有可能发生。 
3.REPEATABLE-READ(可重复读): 
 对同一字段的多次读取结果都是一致的,除非数据是被本身事务自己所修改,可以阻止脏读和不可重复读,但幻读仍有可能发生。 
 4.SERIALIZABLE(可串行化): 
 最高的隔离级别,完全服从ACID的隔离级别。所有的事务依次逐个执行,这样事务之间就完全不可能产生干扰,也就是说,该级别可以防止脏读、不可重复读以及幻读。 

这里需要注意的是:
Mysql 默认采用的 REPEATABLE_READ隔离级别 
Oracle 默认采用的 READ_COMMITTED隔离级别

...全文
210 1 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
CSDN-Ada助手 2023-01-13
  • 打赏
  • 举报
回复
您可以前往 CSDN问答-大数据 发布问题, 以便更快地解决您的疑问

66,827

社区成员

发帖
与我相关
我的任务
社区描述
一个支持DBA沟通交流,分享技术的平台,各类数据库齐聚在此,百花齐放
社区管理员
  • IT邦德
  • java李杨勇
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

欢迎大家投稿,沟通交流,旨在构建一个DBA沟通的平台

更多内容请关注B站:搜索jeames007

微信公众号:IT邦德

试试用AI创作助手写篇文章吧