纷争开始了,国产 sqltoy-orm 5.6.2 发版,正式开启淘汰 mybatis 的征程!
还在争论jpa和mybatis?为什么要在这两者中做选择?为什么不做第三种选择:同时具有JPA的能力也具有比mybatis更优秀的sql解决方案?
淘汰mybatis的理由:
1、mybatis不是一个完整的ORM框架,引发了成百上千的plus系列,你追我赶消耗了太多人的精力去开发去推广去争取用户,让太多项目成为短生命周期项目(又出一个plus了,更有亮点,换!)!
2、mybatis的xml写法让太多没有见过sqltoy xml写法的人见xml就反,走上了极端!
3、mybatis就是一个半成品,让大家以为其做插件为乐!
开源地址:
- github: https://github.com/sagframe/sagacity-sqltoy
- gitee: https://gitee.com/sagacity/sagacity-sqltoy
- idea 插件 (可直接在 idea 中检索安装): https://github.com/threefish/sqltoy-idea-plugins
- sqltoy 脚手架项目:https://gitee.com/momoljw/sss-rbac-admin
- sqltoy lambda 项目: https://gitee.com/gzghde/sqltoy-plus
更新内容
1、优化单笔记录插入PrepareStatement 未关闭的缺陷以及类似场景问题
2、DateUtil 增加获取两个日期间隔秒方法
感谢@legendary 的反馈
JPA 部分
- 类似 JPA 的对象化 CRUD、对象级联加载和新增、更新
- 支持通过 POJO 生成 DDL 以及直接向数据库创建表
- 强化 update 操作,提供弹性字段修改能力,不同于 hibernate 先 load 后修改,而是一次数据库交互完成修改,确保了高并发场景下数据的准确性
- 改进了级联修改,提供了先删除或者先置无效,再覆盖的操作选项
- 增加了 updateFetch、updateSaveFetch 功能,强化针对强事务高并发场景的处理,类似库存台账、资金台账,实现一次数据库交互,完成锁查询、不存在则插入、存在则修改,并返回修改后的结果
- 增加了树结构封装,便于统一不同数据库树型结构数据的递归查询
- 支持分库分表、支持多种主键策略 (额外支持基于 redis 的产生特定规则的业务主键)、加密存储、数据版本校验
- 提供了公共属性赋值 (创建人、修改人、创建时间、修改时间、租户)、扩展类型处理等
- 提供了多租户统一过滤和赋值、提供了数据权限参数带入和越权校验
查询部分
- 极为直观的 sql 编写方式,便于从客户端 <--> 代码 双向快速迁移,便于后期变更维护
- 支持缓存翻译、反向缓存匹配 key 代替 like 模糊查询
- 提供了跨数据库支持能力:不同数据库的函数自动转换适配,多方言 sql 根据实际环境自动匹配、多数据库同步测试,大幅提升了产品化能力
- 提供了取 top 记录、随机记录等特殊场景的查询功能
- 提供了最强大的分页查询机制:1) 自动优化 count 语句;2) 提供基于缓存的分页优化,避免每次都执行 count 查询;3) 提供了独具特色的快速分页;4) 提供了并行分页
- 提供了分库分表能力
- 提供了在管理类项目中极为价值的:分组汇总计算、行列转换 (行转列、列转行)、同比环比、树形排序、树形汇总 相关算法自然集成
- 提供了基于查询的层次化数据结构封装
- 提供了大量辅助功能:数据脱敏、格式化、条件参数预处理等
支持多种数据库
- 常规的 mysql、oracle、db2、postgresql、 sqlserver、dm、kingbase、sqlite、h2、 oceanBase、polardb、guassdb、tidb
- 支持分布式 olap 数据库: clickhouse、StarRocks、greenplum、impala (kudu)
- 支持 elasticsearch、mongodb
- 所有基于 sql 和 jdbc 各类数据库查询
sqltoy 特点介绍:
- sqltoy 的核心构建思想
- sqltoy 的对比 mybatis (plus) 的核心点:查询语句编写、可阅读性、可维护性
- 对象化 crud 是基础,但 sqltoy 有针对性的改进:update、updateSaveFetch、updateFetch 等
- sqltoy 的缓存翻译,大幅减少表关联简化 sql,让你的查询性能成几何级提升
- 极致的分页,同样帮助你实现查询的性能大幅提升
- 快速分页:@fast () 实现先取单页数据然后再关联查询,极大提升速度
- 分页优化器:page-optimize 让分页查询由两次变成 1.3~1.5 次 (用缓存实现相同查询条件的总记录数量在一定周期内无需重复查询
- sqltoy 的分页取总记录的过程不是简单的 select count (1) from (原始 sql);而是智能判断是否变成:select count (1) from 'from 后语句 ', 并自动剔除最外层的 order by
- sqltoy 支持并行查询:parallel="true",同时查询总记录数和单页数据,大幅提升性能
- 便利的跨数据库统计计算:数据旋转
- 便利的跨数据库统计计算:无限极分组统计 (含汇总求平均)
- 便利的跨数据库统计计算:同比环比
6、扩展集成
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
libgit2 v1.8.0 发布,跨平台、可链接的 Git 库实现
libgit2 是一个可以在应用程序中使用的跨平台、可链接的 Git 库实现。libgit2 v1.8.0 “Das Fliegende Klassenzimmer” 现已发布。此版本包括对调用 OpenSSH 进行获取和推送的可选实验性支持、执行git commit默认行为的更简单机制,并对工作树进行了许多改进。此版本还包括许多其他新功能和错误修复。 更新内容如下: Major changes Executable SSH (OpenSSH) 支持 libgit2 现在可以调用 OpenSSH 命令行,通过 SSH 从远程获取并推送到远程。该支持取代了 libssh2 支持。可通过cmake -DUSE_SSH=exec配置使用。#6617 简化 commit 创建git_commit_create_from_stageAPI 的引入是为了让用户更好地模拟git commit的行为,而无需提供不必要的信息。#6716 Worktree 改进 对 worktree 进行了许多改进,以便更好地与 core git 兼容。首先,libgit2 现在可以理解每个 worktree 的引用。其...
- 下一篇
【副屏桌面】天天工作台 9.0 大版本更新,导航栏、文件夹功能升级
各位OSchina的同学,大家好。 想天工作台更名为天天工作台了。与此同时,版本升级至9.x。当然还在公测阶段。 本次更新主题:大大完善了导航逻辑逻辑同时对新手更友好。 更新内容概要: 1.【重大更新】文件夹功能重做 我们重做了整个文件夹功能,对拖拽交互逻辑进行了全面兼容,目前支持直接拖拽工作台外部文件、快捷方式、steam游戏、甚至网址,到文件夹,当然,同期我们还支持了导航栏的各种拖拽操作。 文件夹支持多种列表展现形式、多种尺寸,以及自由拖拽大小。 开发者有话说:支持网址的拖拽,虽然看似小众,但实际上可以实现快速创建个人网址收藏的效果。非常推荐高频使用此功能。 结合后面的浏览器收藏夹功能,可以快速导入自己的浏览器收藏。 导航栏的文件夹效果 2.【重大更新】导航栏功能加强 全面兼容文件夹,基于文件夹的导航栏玩法更多,这是一张参考图。 导航栏还支持自动隐藏模式。 导航栏推荐方案 开发者有话说:我们希望用户能够借助导航栏和文件夹的组合,形成一套自己的快捷启动逻辑。 其中包括了软件和网页的快速启动。我们还计划在下个阶段推出上置的导航栏,这样上下摆放副屏的用户就可以使用起来更加快捷。 3.导...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS8安装Docker,最新的服务器搭配容器使用
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题
- SpringBoot2整合MyBatis,连接MySql数据库做增删改查操作
- CentOS7,CentOS8安装Elasticsearch6.8.6
- Hadoop3单机部署,实现最简伪集群
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- CentOS8编译安装MySQL8.0.19
- SpringBoot2全家桶,快速入门学习开发网站教程
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- SpringBoot2配置默认Tomcat设置,开启更多高级功能