sqlhelper for mysql,GitHub - fangjinuo/sqlhelper at v3.2.2

sqlhelper

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

modules

module

sqlhelper version

JDK

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+

对国产框架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-jdbc 支持 (主要包括:通用分页)

sqlhelper-springjdbc-spring-boot

2.0.2+

1.8+

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

sqlhelper-mybatisplus

2.0.7+

1.6+

对 mybatis-plus 支持

sqlhelper-mybatisplus-spring-boot

2.0.7+

1.8+

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

sqlhelper-tkmapper-spring-boot-starter

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-examples

1.0+

1.8+

为这些工具提供 测试用例

tools usage

关键特性

支持 MyBatis, MyBatis-Plus, 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

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

Apache Commons-DBUtils

X

Subquery pagination

X

solon

X

分页工具使用说明

更多说明,参见教程:

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

2. https://fangjinuo.github.io

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那样顺滑

redisclient: 基于Spring RestTemplate提供的客户端

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

鸣谢

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

sqlhelper for mysql,GitHub - fangjinuo/sqlhelper at v3.2.2_第1张图片

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