在工业界和学术界中数据库的研究热点是什么

首页 / 常见问题 / 低代码开发 / 在工业界和学术界中数据库的研究热点是什么
作者:低代码开发工具 发布时间:24-10-25 13:58 浏览量:1726
logo
织信企业级低代码开发平台
提供表单、流程、仪表盘、API等功能,非IT用户可通过设计表单来收集数据,设计流程来进行业务协作,使用仪表盘来进行数据分析与展示,IT用户可通过API集成第三方系统平台数据。
免费试用

在当前数据库领域最热门的话题之一就是one size can fit all or not,我打算尽可能系统地分析一下,内容会同时覆盖学术界和工业界。划分数据库workload的做法很早就有了,比如AP和TP的划分就是由Codd在1993年提出的。

一、工业界和学术界中数据库的研究热点

在当前数据库领域最热门的话题之一就是one size can fit all or not,我打算尽可能系统地分析一下,内容会同时覆盖学术界和工业界。

分离

划分数据库workload的做法很早就有了,比如AP和TP的划分就是由Codd在1993年提出的。One size cannot fit all的意思就是一种数据库无法满足所有的需求,所以我们需要根据不同需求来造出不同的数据库,这种说法来自于Stonebraker。

Stonebraker在Berkeley时期做出了Ingres、Postgres,与Oracle等数据库供应商展开了激烈的竞争。那时候用RDBMS就可以满足几乎所有数据存储需求,one size can fit all。

而在MIT时期,他到ICDE 2005上发了篇《”One Size Fits All”: An Idea Whose Time Has Come and Gone》,宣告one size can fit all的时代已死,并在不同的场合宣扬,使其广为人知。随后他以身作则排列组合出了各种数据库,包括做OLAP的C-Store(后改名为Vertica),做内存OLTP的H-Store(后改名为VoltDB),做科学计算的SciDB等等,同时不断开公司卖公司,在2014年时就已co-founded了9家公司。

虽然Stonebraker提出one size cannot fit all可能有其商业目的,但这句话本身是有合理性的。数据库中各部分往往耦合臃肿,从头做方便探索针对特定情形的架构设计与优化。想一口气做出AP+TP+relational+graph+JSON+ACID+SQL只能是over design,和GNU Hurd一样止于流产。

通过quad chart排列组合产生数据库idea的方法也来自Stonebraker,并从他的身边的人传播到了整个领域。

融合

话说天下大势,分久必合,合久必分。就在Stonebraker发出one size cannot fit all的豪言没多久,SAP就做出了HANA这个大一统数据库,在SIGMOD 2009会上当着Stonebraker的面上台讲起了同时处理OLAP和OLTP的新型数据库,把Stonebraker搞得气急败坏。

将各种需求统一处理的好处在于它能降低机器、学习、运维等成本,不用同时处理一堆又一堆的组件。大数据生态的那一堆组件互联网企业都头疼,对于传统企业就更困难了。比如OceanBase在解释做HTAP的原因时就举例说,有些用户连AP、TP是什么都不知道,因为他们以前用的是Oracle。

近些年都合并趋势非常之多,细数起来包括以下几点:

  • RDBMS和NoSQL的合并,a.k.a. NewSQL。Andy Povlo在《What’s Really New with NewSQL?》中把NewSQL分为三种:new architectures、database-as-a-service和transparent sharding middleware。虽然很多人都是只把Google Spanner、TiDB这种new architectures和Amazon Aurora这种DBaaS视为NewSQL。
  • 混合事务分析处理,a.k.a HTAP。为了防止AP影响TP,现在HTAP一般都将AP和TP物理隔离成两套系统,在内部通过CDC或者Raft复制等方式进行同步。目前看来,HTAP成功得彻彻底底,占领了越来越多的轻量分析市场。
  • 多种查询能力的融合,a.k.a. 联邦查询。devcon2021报告。联邦查询的概念来自于Postgres,指将其他数据库数据源当成它内部的一张表。以TiDB为代表的HTAP把列存融入了TP中,那能不能像MySQL那样把全文检索、文档甚至graph等也融进去呢?而恰好后来听Milvus

@Zilliz

的报告时发现他们也提到,Milvus等purpose-built数据库除了纵向挖深外,能不能横向融入其他模型的能力呢?比如不少用户呼吁的向量数据库和graph的融合。

  • 批处理和流处理的融合,a.k.a 计算层的流批一体。由于Storm没实现exactly-once语义来保证正确性,其创始人Nathan提出了Lambda架构流批分离。2015年,谷歌发布Dataflow模型,将批处理归为流处理的特殊情况。接着Flink抓住机会采用了Dataflow模型实现了接口层的流批一体,在来自阿里的Blink分支合入后实现了内部运行的流批一体。当然,Spark也在流批一体上奋勇直追,用Structured Streaming替代落后的Spark Streaming,增强了其流处理能力。
  • 文件存储和流存储的融合,a.k.a 存储层的流批一体。通常,流处理读消息队列,批处理读文件系统。近些年,流批一体的趋势从计算层蔓延到了存储层。Iceberg和Hudi等数据湖基于文件来实现队列特性,而Pulsar和Pravega等消息队列基于队列来实现文件特性。在这个场景下,文件的变化可以生成流,流又可以聚合成文件。

分离和融合的本质是用户需求和技术实现的trade off。像MapReduce那样将整个数据库领域推倒重来确实技术上解决了scalable的问题,但代价就是功能完整和使用体验。随着屠龙少年成长为了恶龙,整个领域也开始回归到了分布式的本质,从二选一进化到了全都要。

如果说one size cannot fit all是为了更好地实现功能,那one size can fit all again就是对整个数据库领域的重构。代码的主要功能实现完了,自然该重构了。当然,新的功能还在持续开发,purpose-built数据库也依旧有其市场。

延伸阅读:

二、按照SQL标准的解释Catalog和Schema

在SQL环境下Catalog和Schema都属于抽象概念,可以把它们理解为一个容器或者数据库对象命名空间中的一个层次,主要 用来解决命名冲突问题。从概念上说,一个数据库系统包含多个Catalog,每个Catalog又包含多个Schema,而每个Schema又包含多个数据库对象(表、视图、字段等),反过来讲一个数据库对象必然属于一个Schema,而该Schema又必然属于一个Catalog,这样我们就可以得到该数据库对象的完全限定名称从而解决命名冲突的问题了;例如数据库对象表的完全限定名称就可以表示为:Catalog名称.Schema名称.表名称。这里 还有一点需要注意的是,SQL标准并不要求每个数据库对象的完全限定名称是少数的,就象域名一样,如果喜欢的话,每个IP地址都可以拥有多个域名。

通俗点理解:

schema是对一个数据库的结构描述。在一个关系型数据库里面,schema定义了表、每个表的字段,还有表和字段之间的关系。

catalog是由一个数据库实例的元数据组成的,包括基本表,同义词,索引,用户等等。

或许更通俗还可以这样理解:

schema有点类似于类,catalog有点类似于对象。

最后建议,企业在引入信息化系统初期,切记要合理有效地运用好工具,这样一来不仅可以让公司业务高效地运行,还能最大程度保证团队目标的达成。同时还能大幅缩短系统开发和部署的时间成本。特别是有特定需求功能需要定制化的企业,可以采用我们公司自研的企业级低代码平台织信Informat。 织信平台基于数据模型优先的设计理念,提供大量标准化的组件,内置AI助手、组件设计器、自动化(图形化编程)、脚本、工作流引擎(BPMN2.0)、自定义API、表单设计器、权限、仪表盘等功能,能帮助企业构建高度复杂核心的数字化系统。如ERP、MES、CRM、PLM、SCM、WMS、项目管理、流程管理等多个应用场景,全面助力企业落地国产化/信息化/数字化转型战略目标。 版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们微信:Informat_5 处理,核实后本网站将在24小时内删除。

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系邮箱:hopper@cornerstone365.cn 处理,核实后本网站将在24小时内删除。

最近更新

团队技术研发流程表怎么做
01-17 18:02
怎么改造研发团队研发流程
01-17 18:02
如何优化研发流程以缩短产品上市时间
01-17 18:02
研发流程团队 职责是什么
01-17 18:02
软件传统研发流程包括什么
01-17 18:02
研发流程用什么软件做
01-17 18:02
低代码后台:《低代码后台开发指南》
01-17 17:28
后台低代码:《后台低代码开发技巧》
01-17 17:28
国内最强低代码开发平台:《国内顶尖低代码平台》
01-17 17:28

立即开启你的数字化管理

用心为每一位用户提供专业的数字化解决方案及业务咨询

  • 深圳市基石协作科技有限公司
  • 地址:深圳市南山区科技中一路大族激光科技中心909室
  • 座机:400-185-5850
  • 手机:137-1379-6908
  • 邮箱:sales@cornerstone365.cn
  • 微信公众号二维码

© copyright 2019-2024. 织信INFORMAT 深圳市基石协作科技有限公司 版权所有 | 粤ICP备15078182号

前往Gitee仓库
微信公众号二维码
咨询织信数字化顾问获取最新资料
数字化咨询热线
400-185-5850
申请预约演示
立即与行业专家交流