是时候抛弃 mybaits 了,国产 sqltoy-orm 5.2.84 发版
开源地址:
- 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、优化with t as () 语句不在sql开始位置场景处理,以及优化类似postgre物化CTE语法解析
```sql
with t1 (a, b) as NOT MATERIALIZED (select * from table),t2(c,d) as materialized(select name from ta)
```
2、DateUtil增强对毫秒、纳秒的格式化,同时增强sql日志输出关于LocalDateTime和LocalTime的定制格式
```properties
# 默认 yyyy-MM-dd HH🇲🇲ss,可选auto 或yyyy-MM-dd HH🇲🇲ss.SSSSSSSSS 或yyyy-MM-dd HH🇲🇲ss.SSSSSS等
# auto 表示根据纳秒值来自动设定格式
spring.sqltoy.localDateTimeFormat=yyyy-MM-dd HH🇲🇲ss.SSSSSSSSS
# 默认:HH🇲🇲ss,可选:auto 或HH🇲🇲ss.SSSSSSSSS 或 HH🇲🇲ss.SSS 或 HH🇲🇲ss.SSSSSS
spring.sqltoy.localTimeFormat=HH🇲🇲ss.SSSSSSSSS
```
3、MapperUtil增加PropsMapperConfig来指定只映射哪些属性或排除哪些不映射的属性
```java
/**
* new PropsMapperConfig(ignoreProperties).isIgnore(true))
*/
public static <T extends Serializable> T map(Serializable source, Class<T> resultType,
PropsMapperConfig propsMapperConfig)
```
4、修复83版本in (?) 参数非数组是单个数字字符串处理缺陷
sqltoy-orm 是 JPA 和超强查询的融合体
JPA 部分
- 类似 JPA 的对象化 CRUD、对象级联加载和新增、更新
- 强化 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业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
野火IM 1.2.1 已经发布,即时通讯系统
野火IM 1.2.1 已经发布,即时通讯系统 此版本更新内容包括: Release note 1.2.1: 添加获取在线用户功能。 添加获取用户连接session信息的功能。 优化按照用户id搜索用户的逻辑。 解决广播消息没有发给未登录用户的问题。 附件的版本有3种格式,分别是Java通用版本、Deb格式安装包和Rpm格式安装包包,可以根据平台或者自己的习惯下载其中一种软件包。另外在Github也可以下载。也可以下载我们网站上的最新版本,通用Java包,deb格式安装包和rpm格式安装包。 *** 0.42 版本增加了群成员数限制,默认为2000。如果您想修改默认值,可以在升级版本之后,修改t_setting表,把默认的大小改为您期望的。另外修改t_group表,把已经存在的群组max_member_count改成您期望的,然后重启。*** *** 0.46和0.47版本升级到0.48及以后版本时,可能会提示flyway migrate 38错误,请执行 修复脚本 进行修复。0.46和0.47版本之外的版本不会出现此问题。*** *** 0.50版本添加了是否允许客户端发送群操作通知的...
- 下一篇
ONLYOFFICE 协作空间 2.0 现已发布:新增公共房间、插件、重新分配数据等功能
更新后的ONLYOFFICE协作空间新增诸多实用功能,全平台实现多项优化功能。请继续阅读,了解所有更新。 ONLYOFFICE 协作空间是什么 ONLYOFFICE 协作空间是一款开源效率平台,让您与同事、团队成员、客户、合作伙伴、承包商、赞助商和其他第三方更有效地协作处理办公文档。 该平台提供了一个基于房间的环境,可根据您的需求或项目目标组织文件管理结构。灵活的访问权限和用户角色让您对整个空间或单独房间的访问权限进行调整。 ONLYOFFICE 协作空间 2.0 新功能 公共房间 欢迎查看全新房间类型,让您与第三方协作处理文档更加轻松。 您可以在公共房间中,通过外部链接邀请用户,这样他们无需注册即可查看文件。 设置路径:新房间 -> 公共房间 需要的话,您可以生成多个外部链接,设置不同参数和访问权限。 为确保公共房间中的文件安全,您可以使用密码保护功能,限制对文件内容的复制、下载和打印。 此外,您还可以在开发者工具 -> JavaScript SDK 中使用相应的嵌入设置,轻松将公共房间嵌入到任意网络界面中。这样,您的网站或服务的用户可以直接从网络前端访问房间文件。 房间...
相关文章
文章评论
共有0条评论来说两句吧...