java sqlhelper_GitHub - fangjinuo/sqlhelper: SQL Tools ( Dialect, Pagination, DDL dump, UrlParser, S...

sqlhelper

SQL Tools ( Dialect, Pagination, DDL Dump, UrlParser, SqlStatementParser, WallFilter, BatchExecutor for Test) based Java

modules

module

sqlhelper version

JDK

framework version

Description

sqlhelper-dialect

1.0+

1.6+

the core (绝大部分功能都离不开它)

sqlhelper-cli

2.0+

1.8+

CLI 命令行工具

sqlhelper-cli-assembly

2.0+

1.8+

为 CLI 命令行工具 提供打包功能

sqlhelper-mybatis

1.0+

1.6+

提供对MyBatis的支持 (主要包括:通用分页、通用批量操作、多数据源)

sqlhelper-mybatis-spring-boot

1.0+

1.6+

为MyBatis + SqlHelper 提供了Spring Boot 快速启动

sqlhelper-mybatis-over-pagehelper

1.0+

1.6+

引入它就可以无缝的从 mybatis-pagehelper 迁移到 SqlHelper

sqlhelper-jfinal

1.2+

1.6+

4.3+

对国产框架jfinal支持 (主要包括:通用分页)

sqlhelper-ebean

1.2+

1.6+

对 ebean 支持(主要包括:通用分页)

sqlhelper-hibernate

1.2+

1.6+

对 hibernate 支持(主要包括:通用分页)

sqlhelper-mango

1.2+

1.6+

对 mango 支持 支持(主要包括:通用分页)

sqlhelper-batchinsert

1.2+

1.6+

为了 性能测试 提供的批量入库工具

sqlhelper-springjdbc

2.0.2+

1.6+

spring 4.0+

对 spring-jdbc 支持 (主要包括:通用分页)

sqlhelper-springjdbc-spring-booter

2.0.2+

1.8+

对 spring-jdbc 应用提供了 Spring Boot 快速启动

sqlhelper-mybatisplus-3

2.0.7+

1.8+

mybatis-plus 3.2.0+

对 mybatis-plus 支持

sqlhelper-mybatisplus-spring-boot-starter

2.0.7+

1.8+

mybatis-plus 3.1.2+

对 mybatis-plus 应用提供了 Spring Boot 快速启动

sqlhelper-mybatisplus-2

3.3.0+

1.6+

mybatis-plus 3.2.0+

对 mybatis-plus 支持

sqlhelper-mybatisplus_2x-spring-boot-starter

2.0.7+

1.6+

mybatis-plus 3.1.2+

对 mybatis-plus 应用提供了 Spring Boot 快速启动

sqlhelper-tkmapper-spring-boot-starterer

3.1.0+

1.8+

对 tk.mybatis Mapper 应用提供了 Spring Boot 快速启动

sqlhelper-dbutils

2.2.0

1.6+

对 Apache Commons-DBUtils 支持 (主要包括:通用分页)

sqlhelper-jsqlparser

3.0.3

1.6+

对于要基于SQL Parser接口来完成的功能 由jsqlparser 这个库来实现

sqlhelper-mybatis-solon-plugin

3.2.0

1.8+

支持solon 框架

sqlhelper-datasource

3.4.0

1.6+

提供通用的多数据源配置、解析、路由框架

sqlhelper-mybatis-spring-common

3.4.0

1.6+

提供mybatis + spring 环境下,通用的代码

sqlhelper-examples

1.0+

1.8+

为这些工具提供 测试用例

tools usage

关键特性

支持 MyBatis, MyBatis-Plus, Tk.Mapper, SpringJdbc, Apache Commons-DBUtils, JFinal, EBean, Mango, Hibernate 等众多对数据库操作的框架

支持 110+ 数据库(所有功能均支持,不限于分页功能), 支持的数据库列表参考: DB Engines.下面是所有支持的国产数据库:

AliSQL (阿里 MySQL)

AntDB (亚信)

CirroDB (东方国信 行云)

CynosDB (腾讯云数据库)

Doris (Apache Doris,百度研发)

DM (达梦)

EsgynDB (易鲸捷)

GaussDB (华为 高斯)

GBase (南大通用)

GoldenDB (中兴)

HHDB (恒辉数据库)

HighGo (瀚高)

HybridDB (阿里巴巴 分布式PostgreSQL)

K-DB (浪潮)

KingBase (金仓)

MaxCompute (阿里巴巴)

OBase (上海丛云信息科技)

OceanBase (阿里巴巴/蚂蚁金服 兼容mysql)

OSCAR (神州通用)

OpenBase (东软)

RadonDB (青云)

SequoiaDB (巨杉)

SinoDB (星瑞格)

TDSQL (腾讯 分布式MySQL)

TiDB (北京平凯星辰科技))

Trafodion (易鲸捷 EsgynDB的开源版)

UxDB (优炫数据库)

支持多个数据库在同一个应用中并存,且不需要做任何的区分,就能自动识别

支持自动获取数据库 dialect (方言),也可以指定

性能要比Mybatis-PageHelper更高, 因为SQL中的 limit、offset 会以占位符 '?'的形式存在,支持缓存等,总之PageHelper支持的这里都支持,PageHelper不支持的这里也支持。

对于 select count语句,会自动的排除掉 order by 子句,以提升查询效率

可以基于 Java SPI 规范来自定义Dialect,以此来扩展数据库

分页功能支持子查询:mybatis, mybatis-plus, spring-jdbc, apache commons-dbutils

支持 spring boot 1.x , 2.x

支持 JDK6+

支持 Memory Pagination

支持 SqlSymbolMapper, 可以使用它来自动映射数据库字段、表名等

支持 Dump DDL

支持 like parameter escape [%] : mybatis, mybatis-plus, tk.mapper 下使用

动态数据源 Dynamic DataSource,目前支持在 mybatis, mybatis-plus, tk.mapper 下使用

sqlhelper vs mybatis-pagehelper

metric

mybatis-pagehelper

sqlhelper

databases

13

100+

multiple databases in runtime

auto detect dialect

plugin

PrepareStatement with '?'

X

mybatis

3.x

3.x

spring boot

1.x, 2.x

1.x, 2.x

JDK

1.6+

1.6+

jFinal

X

Mango

X

EBean

X

国产数据库

X

√ (参见上述列表)

Spring JDBC

X

√ 2.x,3.x,4.x,5.x

SqlSymbol Mapping

X

MyBatis-Plus

X

tk.mapper

Apache Commons-DBUtils

X

Subquery pagination

X

solon

X

多数据源

X

分页工具使用说明

更多说明,参见教程:

1. https://fangjinuo.gitee.io/docs/index.html

2. https://fangjinuo.github.io

Dynamic DataSource

目前针对动态(多)数据源这块,提供了方便的,易扩展的框架,可以基于此多数据源框架与各种ORM框架结合。

此外目前内置对 MyBatis 系框架( mybatis, mybatis-plus(2.x, 3.x), tk.mapper 等)做了内置的支持。提供了便利的 spring boot starter。

usage

sqlhelper:

dynamic-datasource:

enabled: true

datasources:

- group: A

name: master

url: jdbc:h2:file:${user.dir}/sqlhelper-examples/sqlhelper-examples-db/src/main/resources/test

driver-class-name: org.h2.Driver

username: sa

password: 123456

- group: A

name: slave-1

url: jdbc:h2:file:${user.dir}/sqlhelper-examples/sqlhelper-examples-db/src/main/resources/test

driver-class-name: org.h2.Driver

username: sa

password: 123456

- group: A

name: slave-2

url: jdbc:h2:file:${user.dir}/sqlhelper-examples/sqlhelper-examples-db/src/main/resources/test

driver-class-name: org.h2.Driver

username: sa

password: 123456

- group: B

name: mysql

url: jdbc:h2:file:${user.dir}/sqlhelper-examples/sqlhelper-examples-db/src/main/resources/test

driver-class-name: org.h2.Driver

username: sa

password: 123456

- group: C

name: oracle

url: jdbc:h2:file:${user.dir}/sqlhelper-examples/sqlhelper-examples-db/src/main/resources/test

driver-class-name: org.h2.Driver

username: sa

password: 123456

- group: C

name: xxxx

url: jdbc:h2:file:${user.dir}/sqlhelper-examples/sqlhelper-examples-db/src/main/resources/test

driver-class-name: org.h2.Driver

username: sa

password: 123456

事务控制:

目前做法:

针对每一个数据源,都添加一个 TransactionManager。各自控制自己的。

Dynamic DataSource - 开发计划

通用框架

连接池实现

支持常见连接池:HikariCP, Alibaba Druid, tomcat-jdbc, dbcp2, c3p0

支持在配置中使用哪个连接池实现

支持所用连接池实现的特有配置项

DataSource 配置

支持分组配置,通常一个业务群一个分组,或者一个数据库集群用一个分组

兼容 SpringBoot 默认 DataSource 配置

支持多种异构数据源

DataSource 识别

提供 @DataSource 注解,可以在 method, class 级别使用

支持 自定义注解。

支持多层级 注解配置。筛选时,安装最近优先原则

支持自定义识别算法。例如可以基于此自行实现负载均衡,读写分离,随机等众多识别算法。

支持多层嵌套。

可自定义AOP拦截位置。

Router

master, slave 识别

基于 readonly 确定是否必定为slave

基于 primary 判断

如果没有primary属性则 基于 name 判断

master 路由算法

first,即只取第一个

slave 路由算法

随机路由

读写分离路由

负载均衡路由

故障转移

框架支持

mybatis & spring boot 应用

mybatis 2.x, 3x & spring boot 应用

tk.mapper & spring boot 应用

spring jdbc

apache DBUtils

jfinal

UrlParser

Parse jdbc url.

usage:

String url = "jdbc:mysql://${localhost}:${port}....";

DatabaseInfo dbinfo = new JdbcUrlParser().parse(url)

...

Batch Insert Tool

如果你想要进行业务SQL性能优化,又苦于数据库里没有太多数据,可以使用它来进行批量插入数据,大大的节省你造数据的时间。具体参加sqlhelper-batchinsert模块。

这里提供了一些常见问题,对于刚使用SQLHelper时,可能对你很有帮助

Contact

QQ 交流群: 750929088

langx 系列

langx-js:TypeScript, JavaScript tools

langx-java: Java tools ,可以替换guava, apache commons-lang,io, hu-tool等

easyjson: 一个通用的JSON库门面,可以无缝的在各个JSON库之间切换,就像slf4j那样。

sqlhelper: SQL工具套件(通用分页、DDL Dump、SQLParser、URL Parser、批量操作工具等)。

esmvc: ElasticSearch 通用客户端,就像MyBatis Mapper那样顺滑

agileway: 提供大量的框架扩展,方便日常开发

audit:通用的Java应用审计框架

鸣谢

最后,感谢 Jetbrains 提供免费License,方便了开源项目的发展。

f7f3d54c9c1efb8e7ae5ff39b6e6cf4e.png

你可能感兴趣的:(java,sqlhelper)