数据源的统一与拆分 apache calcite 的雄心与现实

devtools/2024/11/28 16:57:29/

随笔

从千万粉丝“何同学”抄袭开源项目说起,为何纯技术死路一条?

数据源的统一与拆分 apache calcite 的雄心与现实

报警系统的指标、规则与执行闭环

java 老矣,尚能饭否?

一骑红尘妃子笑,无人知是荔枝来!

数据库的分类

数据库作为我们常用的底层服务之一,有很多的种类。

数据库的分类

每一种数据库都有对应的查询语句。比如 mysql / oracle / mongodb / es / vm 等等...

这么多,怎么记得住呢?

统一

有没有类似于 slf4j 统一日志输出一样,也有人统一一下 SQL 的查询呢?

答案是有的。

apache calcite 提供了一个行业标准的 SQL 解析器和验证器,一个可定制的优化器,具有可插拔规则和成本函数,逻辑和物理代数运算符,从 SQL 到代数(以及相反)的各种转换算法,以及许多适配器,用于在 Cassandra、Druid、Elasticsearch、MongoDB、Kafka 等系统上执行 SQL 查询,配置最小。

calcite

方言

不过实际使用中,发现对于一些方言语法的兼容还是没那么好。

一开始想设计 SQL 引擎的时候使用,但是实际上发现业务方使用 SQL 造诣非常之高,乃至很多语法 calcite 并不支持。

所以使用体验反而会很差,权衡之下, mysql/oracle 还是选择了使用原生的语法。

为什么不能全部统一

不同的数据库解决不同的场景难题,不同的流派有着自己的理念优势,不同的民族有着独特的文化美食。

文化差异

取长补短,兼容并包,方是正道。


http://www.ppmy.cn/devtools/137710.html

相关文章

C#设计模式——抽象工厂模式(重点)

文章目录 项目地址一、抽象工厂模式1.1 特性1.2 使用反射获取特性标记的类1.3 完整代码 项目地址 教程作者:教程地址: 代码仓库地址: 所用到的框架和插件: dbt airflow一、抽象工厂模式 工厂方法模式依然存在一个问题就是&…

git命令备忘录

1、git rebase 把某个分支的commit重新应用到另一个分支的基础上: A0————A1————A2————A3————A4 \ B1————B2————B3 假如有两个分支A和B,在A1的变更提交到A分支后以此作为基准拉取B分支,此后A分支提交了A2、A3、A4变更…

VsCode 插件推荐(个人常用)

VsCode 插件推荐(个人常用)

pgadmin安装后运行不能启动界面的问题

在本人机器上安装了pgsql10后,自带的pgadmin安装后运行时能打开edge并显示数据库server和数据库的,后来又安装了pgsql17,结果安装后想打开pgadmin,结果一直在等待最后,爆出类似于下面的错误。 pgAdmin Runtime Enviro…

Qt中CMakeLists.txt解释大全

‌Qt从Qt5.15版本开始正式推荐使用CMake进行项目管理‌。 在Qt 5.15之前,虽然可以使用CMake进行构建,但Qt官方更推荐使用qmake。 然而,从Qt5.15开始,Qt官方正式推荐使用CMake作为主要的构建系统,并在Qt 6中进一步加强了…

随手记:鼠标触顶方法

// 鼠标触顶方法 scrollMethod() { window.onscroll () > { let t document.documentElement.scrollTop || document.body.scrollTop; if(t > 10) { this.positionStyle.top 0px; }else{ this.positionStyle.top 128px; } } },

【前端学习笔记】ES6 新特性

ES 新特性 1.let、const关键字var、let、const的区别? 2.变量的解构赋值3.新增Symbol4.模板字符串字符串新方法 5.rest参数6.运算符spread 扩展运算符可选链 ?.函数绑定运算符::指数运算符 ** 7.对象Object对象简写新增Map新增Set数组新方法object新方法 8.函数参数…

聊聊Flink:这次把Flink的触发器(Trigger)、移除器(Evictor)讲透

一、触发器(Trigger) Trigger 决定了一个窗口(由 window assigner 定义)何时可以被 window function 处理。 每个 WindowAssigner 都有一个默认的 Trigger。 如果默认 trigger 无法满足你的需要,你可以在 trigger(…) 调用中指定自定义的 tr…