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

随笔

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

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

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

java 老矣,尚能饭否?

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

数据库的分类

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

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

这么多,怎么记得住呢?

统一

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

答案是有的。

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

方言

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

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

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

为什么不能全部统一

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

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

相关推荐
保持学习ing几秒前
SpringBoot前后台交互 -- 登录功能实现(拦截器+异常捕获器)
java·spring boot·后端·ssm·交互·拦截器·异常捕获器
gadiaola6 分钟前
【JVM面试篇】高频八股汇总——类加载和类加载器
java·jvm·面试
七七&55611 分钟前
【Java开发日记】基于 Spring Cloud 的微服务架构分析
java·spring cloud·架构
小猫咪怎么会有坏心思呢20 分钟前
华为OD机考-数字游戏-逻辑分析(JAVA 2025B卷)
java·游戏·华为od
Aesopcmc23 分钟前
idea 启动jar程序并调试
java·intellij-idea·jar
南极Ou1 小时前
Mybatis逆向工程详解(附源码文件)动态创建实体类、条件扩展类、Mapper接口、Mapper.xml映射文件
xml·java·mybatis
Moshow郑锴1 小时前
IDEA为何一直无法使用超过4g内存
java·ide·intellij-idea
木头左1 小时前
Docker容器化镜像分层原理及优化策略
java·eureka
李少兄1 小时前
IntelliJ IDEA代码提示忽略大小写设置详解
java·ide·intellij-idea
白宇横流学长1 小时前
基于SpringBoot实现的课程答疑系统设计与实现【源码+文档】
java·spring boot·后端