gitbook/MySQL实战45讲/docs/67888.md
2022-09-03 22:05:03 +08:00

5.7 KiB
Raw Blame History

开篇词 | 这一次让我们一起来搞懂MySQL

你好我是林晓斌网名“丁奇”欢迎加入我的专栏和我一起开始MySQL学习之旅。我曾先后在百度和阿里任职从事MySQL数据库方面的工作一步步地从一个数据库小白成为MySQL内核开发人员。回想起来从我第一次带着疑问翻MySQL的源码查到答案至今已经有十个年头了。在这个过程中走了不少弯路但同时也收获了很多的知识和思考希望能在这个专栏里分享给你。

记得刚开始接触MySQL是我在百度贴吧做权限系统的时候。我们遇到了一个奇怪的问题一个正常10毫秒就能完成的SQL查询请求偶尔要执行100多毫秒才结束。当时主管问我是什么原因我其实也搞不清楚就上网查答案但怎么找都找不到又脸皮薄不想说自己不知道只好硬着头皮翻源码。后来遇到了越来越多的问题也是类似的情景所以我逐步养成了通过分析源码理解原理的习惯。

当时我自己的感觉是即使我只是一个开发工程师只是MySQL的用户在了解了一个个系统模块的原理后再来使用它感觉是完全不一样的。当在代码里写下一行数据库命令的时候我就能想到它在数据库端将怎么执行它的性能是怎么样的怎样写能让我的应用程序访问数据库的性能最高。进一步哪些数据处理让数据库系统来做性能会更好哪些数据处理在缓存里做性能会更好我心里也会更清楚。在建表和建索引的时候我也会更有意识地为将来的查询优化做综合考虑比如确定是否使用递增主键、主键的列怎样选择等等。

但随后我又有了一个新的困惑我觉得自己了解的MySQL知识点是零散的没有形成网络。于是解决完一个问题后很容易忘记。再碰到类似的问题我又得再翻一次代码。

所幸在阿里工作的时候我参与了阿里云关系型数据库服务内核的开发并且负责开发开源分支AliSQL让我对MySQL内核和源码有了更深层次的研究和理解。在服务内部客户和公有云客户的过程中我有机会面对和解决足够多的问题再通过手册进行系统的学习算是比较坎坷地将MySQL的知识网络补了起来。

所以,在回顾这个过程的时候,我的第一个感受是,如果一开始就有一些从理论到实战的系统性指导,那该多好啊,也许我可以学习得更快些。

在极客时间团队跟我联系策划这个专栏的时候我还是持怀疑态度的。为什么呢现在不比当年了犹记得十余年前你使用MySQL的过程中碰到问题的话基本上都只能到代码里去找答案因为那时网上的资料太少了。

而近十年来MySQL在中国广泛普及技术分享文章可以说是浩如烟海。所以现在要系统地介绍一遍MySQL的话恐怕里面提及的大多数知识点都可以在社区文章中找到。那么我们做这个专栏的意义在哪里而它又凭什么可以收费呢

直到收到极客时间团队的答复我才开始对这个专栏“想做和可以做”的事情感觉清晰起来。数据库是一个综合系统其背后是发展了几十年的数据库理论。同时数据库系统也是一个应用系统可能一个业务开发人员用了两三年MySQL还未必清楚那些自己一直在用的“最佳实践”为什么是最佳的。

于是我希望这个专栏能够帮助这样的一些开发者他们正在使用MySQL知道如何写出逻辑正确的SQL语句来实现业务目标却不确定这个语句是不是最优的他们听说了一些使用数据库的最佳实践但是更想了解为什么这么做他们使用的数据库偶尔会出问题亟需了解如何更快速、更准确地定位问题甚至自己解决问题……

在过去的七年里,我带过十几个应届毕业生,看着他们成长,要求他们原理先行,再实践验证。几年下来,他们的成长速度都很快,其中好几个毕业没两年就成为团队的骨干力量了。我也在社招的时候面试过很多有着不错的运维实践经验和能力的候选人,但都因为对数据库原理仅有一知半解的了解,而最终遗憾地没有通过面试。

因此,我希望这个专栏能够激发开发者对数据库原理的探索欲,从而更好地理解工作中遇到的问题,更能知道背后的为什么。所以我会选那些平时使用数据库时高频出现的知识,如事务、索引、锁等内容构成专栏的主线。这些主线上是一个个的知识点。每个点就是一个概念、一个机制或者一个原理说明。在每个说明之后,我会和你讨论一个实践相关的问题。

希望能以这样的方式让你对MySQL的几条主线有一个整体的认识并且了解基本概念。在之后的实践篇中我会引用到这些主线的知识背景并着力说明它们是怎样指导实践的。这样你可以从点到线再到面形成自己的MySQL知识网络。

在这里,有一份目录,你也可以先了解下整个专栏的知识结构。

如前面说的这几条主线上的每个知识点几乎都不是最新的有些甚至十年前就这样并没有改过。但我希望针对这些点的说明可以让你在使用MySQL时心里更有底知道怎么做选择并且明白为什么。了解了原理才能在实践中不断创新提升个人的价值和工作输出。

从这里开始跟我一起搞懂MySQL!