太厉害了!华为大牛终于把 MySQL 讲的明明白白(基础 + 优化 + 架构)

本文主要是介绍太厉害了!华为大牛终于把 MySQL 讲的明明白白(基础 + 优化 + 架构),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

爱因斯坦说过“耐心和恒心总会得到报酬的”,我也一直把这句话当做自己的座右铭,这句箴言在今年也彻底在“我”身上实现了。

每一个程序员都拥有一座大厂梦,我也不例外,去年面试阿里,竟然被 MySQL 问倒了,很多相关性的问题都没有答上来,才 2 面就凉凉了。为面试做了很多准备,收集很多关于 MySQL 面试题。

MySQL 有哪些特性?

  1. 使用 C 和 C++编写,并使用了多种编译器进行测试,保证源代码的可移植性

  2. 支持 AIX、FreeBSD、HP-UX、Linux、MacOS、Novell Netware、OpenBSD、OS/2 Wrap、Solaris、Windows 等多种操作系统

  3. 为多种编程语言提供了 API。这些编程语言包括 C、C++、Python、Java、Perl、PHP、Eiffel、Ruby 和 Tcl 等。

  4. 支持多线程,充分利用 CPU 资源

  5. 化的 SQL 查询算法,有效地提高查询速度

  6. 既能够作为一个单独的应用程序应用在客户端服务器网络环境中,也能够作为一个库而嵌入到其他的软件中提供多语言支持,常见的编码如中文的 GB 2312、BIG5,日文的 Shift_JIS 等都可以用作数据表名和数据列名

  7. 提供 TCP/IP、ODBC 和 JDBC 等多种数据库连接途径

  8. 提供用于管理、检查、优化数据库操作的管理工具

  9. 可以处理拥有上千万条记录的大型数据库

走进 MySQL 的世界

1、MySQL 性能优化的 21 个最佳实践

  1. 为查询缓存优化你的查询

  2. EXPLAIN 你的 SELECT 查询

  3. 当只要一行数据时使用 LIMIT 1

  4. 为搜索字段建索引

  5. 在 Join 表的时候使用相当类型的例,并将其索引

  6. 千万不要 ORDER BY RAND()

  7. 避免 SELECT *

  8. 永远为每张表设置一个 ID

  9. 使用 ENUM 而不是 VARCHAR

  10. 从 PROCEDURE ANALYSE() 取得建议

  11. 尽可能的使用 NOT NULL

  12. Prepared Statements

  13. 无缓冲的查询

  14. 把 IP 地址存成 UNSIGNED INT

  15. 固定长度的表会更快

  16. 垂直分割

  17. 拆分大的 DELETE 或 INSERT 语句

  18. 越小的列会越快

  19. 选择正确的存储引擎

  20. 选择正确的存储引擎

  21. 小心“永久链接”

2、MySQL 面试题总结

之前的阿里面试题都有做总结,具体面试题内容整理成了文档,本文是针对 MySQL 系列的,所以下面只展示了自己第一次面试阿里时被吊打问到的一些 MySQL 难题,下面是今年面试阿里遇到 MySQL 的题目。

2.1.其他专题内容(含答案)的文档资料

  1. 请解释关系型数据库概念及主要特点?

  2. 请说出关系型数据库的典型产品、特点及应用场景?

  3. 请详细描述 SQL 语句分类及对应代表性关键字。

  4. 什么是 MySQL 多实例,如何配置 MySQL 多实例?

  5. 如何加强 MySQL 安全,请给出可行的具体措施?

  6. 误操作执行了一个 drop 库 SQL 语句,如何完整恢复?

  7. 详述 MySQL 主从复制原理及配置主从的完整步骤。

  8. MySQL 如何实现双向互为主从复制,并说明应用场景?

  9. MySQL 如何实现级联同步,并说明应用场景?

  10. MySQL 主从复制故障如何解决?

2.2.MySQL55 道面试专题你能答出多少?

  1. 一张表,里面有 ID 自增主键,当 insert 了 17 条记录之后,删除了第 15,16,17 条记录,再把 Mysql 重启,再 insert 一条记录,这条记录的 ID 是 18 还是 15 ?

  2. Mysql 的技术特点是什么?

  3. Heap 表是什么?

  4. Mysql 服务器默认端口是什么?

  5. 与 Oracle 相比,Mysql 有什么优势?

  6. 如何区分 FLOAT 和 DOUBLE?

  7. 区分 CHAR_LENGTH 和 LENGTH?

  8. 请简洁描述 Mysql 中 InnoDB 支持的四种事务隔离级别名称,以及逐级之间的区别?

  9. 在 Mysql 中 ENUM 的用法是什么?

  10. 如何定义 REGEXP?

  11. CHAR 和 VARCHAR 的区别?

  12. 列的字符串类型可以是什么?

  13. 如何获取当前的 Mysql 版本?

  14. Mysql 中使用什么存储引擎?

  15. Mysql 驱动程序是什么?

  16. TIMESTAMP 在 UPDATE CURRENT_TIMESTAMP 数据类型上做什么?

  17. 主键和候选键有什么区别?

  18. 如何使用 Unix shell 登录 Mysql?

  19. myisamchk 是用来做什么的?

  20. MYSQL 数据库服务器性能分析的方法命令有哪些?

  21. 如何控制 HEAP 表的最大尺寸?

  22. MyISAM Static 和 MyISAM Dynamic 有什么区别?

  23. federated 表是什么?

  24. 如果一个表有一列定义为 TIMESTAMP,将发生什么?

  25. 列设置为 AUTO INCREMENT 时,如果在表中达到最大值,会发生什么情况?

  26. 怎样才能找出最后一次插入时分配了哪个自动增量?

  27. 你怎么看到为表格定义的所有索引?

  28. LIKE 声明中的%和_是什么意思?

  29. 如何在 Unix 和 Mysql 时间戳之间进行转换?

  30. 列对比运算符是什么?

  31. 我们如何得到受查询影响的行数?

  32. Mysql 查询是否区分大小写?

  33. LIKE 和 REGEXP 操作有什么区别?

  34. BLOB 和 TEXT 有什么区别?

  35. mysql_fetch_array 和 mysql_fetch_object 的区别是什么?

  36. 我们如何在 mysql 中运行批处理模式?

  37. MyISAM 表格将在哪里存储,并且还提供其存储格式?

  38. Mysql 中有哪些不同的表格?

  39. ISAM 是什么?

  40. InnoDB 是什么?

  41. Mysql 如何优化 DISTINCT?

  42. 如何输入字符为十六进制数字?

  43. 如何显示前 50 行?

  44. 可以使用多少列创建索引?

  45. NOW()和 CURRENT_DATE()有什么区别?

  46. 什么样的对象可以使用 CREATE 语句创建?

  47. Mysql 表中允许有多少个 TRIGGERS?

  48. 什么是非标准字符串类型?

  49. 什么是通用 SQL 函数?

  50. 解释访问控制列表

  51. MYSQL 支持事务吗?

  52. mysql 里记录货币用什么字段类型好

  53. MYSQL 数据表在什么情况下容易损坏?

  54. mysql 有关权限的表都有哪几个?

  55. Mysql 中有哪几种锁?

3、MySQL 性能调优与架构设计

  • 基础篇:

  1. MySQL 基本介绍

  2. MySQL 架构组成

  3. MySQL 存储引擎简介

  4. MySQL 安全管理

  5. MySQL 备份与恢复

  • 性能优化篇:

  1. 影响 MySQLServer 性能的相关因素

  2. MySQL 数据库锁定机制

  3. MySQL 数据库 Query 的优化

  4. MySQL 数据库 Schema 设计的性能优化

  5. MySQLServer 性能优化

  6. 常用存储引擎优化

  • 架构设计篇:

  1. MySQL 可扩展设计的基本原则

  2. 可扩展性设计之 MySQLReplication

  3. 可扩展性设计之数据切分

  4. 可扩展性设计之 Cache 与 Search 的..

  5. MySQLCluster

  6. 高可用设计之思路及方案

  7. 高可用设计之 MySQL 监控

MySQL 架构与历史

和其他数据库系统相比,MySQL 有点与众不同,它的架构可以在多种不同场景中应用并发挥好的作用,但同时也会带来-点选择上的困难。MySQL 并不完美,却足够灵活,能够适应高要求的环境,例如 Web 类应用。同时,MySQL 既可以嵌入到应用程序中,也可以支持数据仓库、内容索引和部署软件、高可用的冗余系统、在线事务处理系统(OLTP)等各种应用类型。

史上最全 MySQL 实战文档,需要的朋友可以私信即可免费领取。

服务器性能剖析

在我们的技术咨询生涯中,最常碰到的三个性能相关的服务请求是:如何确认服务器是否达到了性能最佳的状态、找出某条语句为什么执行不够快,以及诊断被用户描述成“停顿"、“堆积"或者“卡死"的某些间歇性疑难故障。本章将主要针对这三个问题做出解答。我们将提供- - 些工具和技巧来优化整机的性能、优化单条语句的执行速度,以及诊断或者解决那些很难观察到的问题(这些问题用户往往很难知道其根源,有时候甚至都很难察觉到它的存在)。

查询性能优化

前面是介绍了如何设计最优的库表结构、如何建立最好的索引,这些对于高性能来说是必不可少的。但这些还不够一还需 要合理的设计查询。如果查询写得很糟糕,即使库表结构再合理、索引再合适,也无法实现高性能。

MySQL 高级特性

MySQL 从 5.0 和 5.1 版本开始引入了很多高级特性,例如分区、触发器等,这对有其他关系型数据库使用背景的用户来说可能并不陌生。这些新特性吸引了很多用户开始使用 MySQL。不过,这些特性的性能到底如何,还需要用户真正使用过才能知道。这里我们将为大家介绍,在真实的世界中,这些特性表现如何,而不是只简单地介绍参考手册或者宜传材料.上的数据。

优化服务器设置

这里我们将解释为 MySQL 服务器创建一个靠谱的配置文件的过程。这是一个很绕的过程,有很多有意思的关注点和值得关注的思路。关注这些点很有必要,因为创建个好配置的最快方法不是从学习配置项开始,也不是从问哪个配置项应该怎么设置或者怎么修改开始,更不是从检查服务器行为和询问哪个配置项可以提升性能开始。

最好是从理解 MySQL 内核和行为开始。然后可以利用这些知识来指导配置 MySQL.最后,可以将想要的配置和当前配置进行比较,然后纠正重要并且有价值的不同之处。

复制

MySQL 内建的复制功能是构建基于 MySQL 的大规模、高性能应用的基础,这类应用使用所谓的“水平扩展”的架构。我们可以通过为服务器配置一个或多个备库生 1 的方式来进行数据同步。复制功能不仅有利于构建高性能的应用,同时也是高可用性、可扩展性、灾难恢复、备份以及数据仓库等工作的基础。事实上,可扩展性和高可用性通常是相关联的话题,我们会在接下来的三章详细阐述。

可扩展的 MySQL

在此将展示如何构建-一个 基于 MySQL 的应用,并且当规模变得越来越庞大时,还能保证快速、高效并且经济。有些应用仅仅适用于--台或少数几台服务器,那么哪些可扩展性建议是和这些应用相关的呢?大多数人从不会维护超大规模的系统,井且通常也无法效仿在主流大公司所使用的策略。本章会涵盖这- - 系列的策略。我们已经建立或者协助建立了许多应用,包括从单台或少量服务器的应用到使用上千台服务器的应用。选择一个合适的策略能够大大地节约时间和金钱。MySQL 经常被批评很难进行扩展,有些情况下这种看法是正确的,但如果选择正确的架构并很好地实现,就能够非常好地扩展 MySQL.但是扩展性并不是-一个很好理解的主题,所以我们先来理清- -些容易混淆的地方。

云端的 MySQL

应用层优化

如果在提高 MySQL 的性能上花费太多时间,容易使视野局限于 MySQL 本身,而忽略了用户体验。回过头来看,也许可以意识到,或许 MySQL 已经足够优化,对于用户看到的响应时间而言,其所占的比重已经非常之小,此时应该关注下其他部分了。这是个很不错的观点,尤其是对 DBA 而言,这是很值得去做的正确的事。但如果不是 MySQL,那又是什么导致了问题呢?使用第 3 章提到的技术,通过测量可以快速而准确地给出答案。如果能顺着应用的逻辑过程从头到尾来剖析,那么找到问题的源头一般来说并不困难。有时,尽管问题在 MySQL.上,也很容易在系统的另一部分得到解决。

备份和恢复

如果没有提前做好备份规划,也许以后会发现已经错失了- -些最佳的选择。例如,在服务器已经配置好以后,才想起应该使用 LVM,以便可以获取文件系统的快照一但这时已经太迟了。在为备份配置系统参数时,可能没有注意到某些系统配置对性能有着重要影响。如果没有计划做定期的恢复演练,当真的需要恢复时,就会发现并没有那么顺利。

MySQL 用户工具

MySQL 服务器发行包中并没有包含针对许多常用任务的工具,例如监控服务器或比较不同服务器间数据的工具。幸运的是,Oracle 的商业版提供了- -些扩展工具,并且 MySQL 活跃的开源社区和第三方公司也提供了- -系列的工具,降低了自己“重复发明轮子”的需要。

总目录

这篇关于太厉害了!华为大牛终于把 MySQL 讲的明明白白(基础 + 优化 + 架构)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/820458

相关文章

将sqlserver数据迁移到mysql的详细步骤记录

《将sqlserver数据迁移到mysql的详细步骤记录》:本文主要介绍将SQLServer数据迁移到MySQL的步骤,包括导出数据、转换数据格式和导入数据,通过示例和工具说明,帮助大家顺利完成... 目录前言一、导出SQL Server 数据二、转换数据格式为mysql兼容格式三、导入数据到MySQL数据

MySQL分表自动化创建的实现方案

《MySQL分表自动化创建的实现方案》在数据库应用场景中,随着数据量的不断增长,单表存储数据可能会面临性能瓶颈,例如查询、插入、更新等操作的效率会逐渐降低,分表是一种有效的优化策略,它将数据分散存储在... 目录一、项目目的二、实现过程(一)mysql 事件调度器结合存储过程方式1. 开启事件调度器2. 创

SQL Server使用SELECT INTO实现表备份的代码示例

《SQLServer使用SELECTINTO实现表备份的代码示例》在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误,在SQLServer中,可以使用SELECTINT... 在数据库管理过程中,有时我们需要对表进行备份,以防数据丢失或修改错误。在 SQL Server 中,可以使用 SE

mysql外键创建不成功/失效如何处理

《mysql外键创建不成功/失效如何处理》文章介绍了在MySQL5.5.40版本中,创建带有外键约束的`stu`和`grade`表时遇到的问题,发现`grade`表的`id`字段没有随着`studen... 当前mysql版本:SELECT VERSION();结果为:5.5.40。在复习mysql外键约

SQL注入漏洞扫描之sqlmap详解

《SQL注入漏洞扫描之sqlmap详解》SQLMap是一款自动执行SQL注入的审计工具,支持多种SQL注入技术,包括布尔型盲注、时间型盲注、报错型注入、联合查询注入和堆叠查询注入... 目录what支持类型how---less-1为例1.检测网站是否存在sql注入漏洞的注入点2.列举可用数据库3.列举数据库

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Mysql虚拟列的使用场景

《Mysql虚拟列的使用场景》MySQL虚拟列是一种在查询时动态生成的特殊列,它不占用存储空间,可以提高查询效率和数据处理便利性,本文给大家介绍Mysql虚拟列的相关知识,感兴趣的朋友一起看看吧... 目录1. 介绍mysql虚拟列1.1 定义和作用1.2 虚拟列与普通列的区别2. MySQL虚拟列的类型2

mysql数据库分区的使用

《mysql数据库分区的使用》MySQL分区技术通过将大表分割成多个较小片段,提高查询性能、管理效率和数据存储效率,本文就来介绍一下mysql数据库分区的使用,感兴趣的可以了解一下... 目录【一】分区的基本概念【1】物理存储与逻辑分割【2】查询性能提升【3】数据管理与维护【4】扩展性与并行处理【二】分区的

C#使用HttpClient进行Post请求出现超时问题的解决及优化

《C#使用HttpClient进行Post请求出现超时问题的解决及优化》最近我的控制台程序发现有时候总是出现请求超时等问题,通常好几分钟最多只有3-4个请求,在使用apipost发现并发10个5分钟也... 目录优化结论单例HttpClient连接池耗尽和并发并发异步最终优化后优化结论我直接上优化结论吧,

Java内存泄漏问题的排查、优化与最佳实践

《Java内存泄漏问题的排查、优化与最佳实践》在Java开发中,内存泄漏是一个常见且令人头疼的问题,内存泄漏指的是程序在运行过程中,已经不再使用的对象没有被及时释放,从而导致内存占用不断增加,最终... 目录引言1. 什么是内存泄漏?常见的内存泄漏情况2. 如何排查 Java 中的内存泄漏?2.1 使用 J