从需求出发来看关系模型与非关系模型–关系模型与非关系模型概述
这篇讲的是关系模型与非关系模型的选择根源。作者从当前对 NoSQL 的盲目追捧现象切入,指出许多项目初创团队都在纠结如何选择 NoSQL,却忽略了模型本身的本质。 文章的核心是帮读者理清 RDBMS、NoSQL、CAP、BASE 这些概念的本源,并用一个“车”的例子清晰地对比了层次模型和关系模型的差异。关键在于,关系模型通过集合运算抽象了数据“关系”,让用户无需像层次模型那样关心从“车”到“轮子集合”再到“具体轮子”的存取路径,只需关注查询逻辑本身,这使得它严谨且被广泛接受。 然而,随着面向对象编程的普及,关系模型带来了“阻抗失配”问题——将对象中的继承、组合映射到关系表变得非常痛苦。为解决此问题,业界尝试了 ORM 工具、在数据库层支持对象,以及利用脚本语言的动态特性来简化映射。这些方案各有代价,ORM 学习成本高且易导致低效查询,而用 Map 则会破坏封装性。 随着互联网发展,对高性能和灵活数据结构的需求,让层次模型的变种——NoSQL 重新受到关注。文章接下来将从具体应用场景出发,剖析关系模型在哪些地方力不从心,以及 NoSQL 为何又能满足新的需求。