Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/bes2008/sqlhelper
SQL Tools ( Dialect, Pagination, DDL dump, UrlParser, SqlStatementParser, WallFilter, BatchExecutor for Test) based Java. it is easy to integration into any ORM frameworks
https://github.com/bes2008/sqlhelper
batchexecutor dao database ddl dialect ebean jdbc jfinal mango mybatis mybatis-pagehelper orm pagination spring-boot spring-jdbc sql urlparser
Last synced: about 4 hours ago
JSON representation
SQL Tools ( Dialect, Pagination, DDL dump, UrlParser, SqlStatementParser, WallFilter, BatchExecutor for Test) based Java. it is easy to integration into any ORM frameworks
- Host: GitHub
- URL: https://github.com/bes2008/sqlhelper
- Owner: bes2008
- License: apache-2.0
- Created: 2019-05-05T09:04:56.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2025-01-03T19:22:24.000Z (9 days ago)
- Last Synced: 2025-01-05T06:09:29.027Z (7 days ago)
- Topics: batchexecutor, dao, database, ddl, dialect, ebean, jdbc, jfinal, mango, mybatis, mybatis-pagehelper, orm, pagination, spring-boot, spring-jdbc, sql, urlparser
- Language: Java
- Homepage: https://github.com/fangjinuo/sqlhelper
- Size: 4.23 MB
- Stars: 311
- Watchers: 16
- Forks: 64
- Open Issues: 23
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Security: SECURITY.md
Awesome Lists containing this project
- awesome-hacking-lists - bes2008/sqlhelper - SQL Tools ( Dialect, Pagination, DDL dump, UrlParser, SqlStatementParser, WallFilter, BatchExecutor for Test) based Java. it is easy to integration into any ORM frameworks (Java)
README
[![License](https://img.shields.io/badge/license-LGPL3.0-green.svg)](https://github.com/fangjinuo/sqlhelper/blob/master/LICENSE)
[![Build Status](https://www.travis-ci.org/fangjinuo/sqlhelper.svg?branch=master)](https://travis-ci.org/fangjinuo/sqlhelper)
[![Codacy Badge](https://api.codacy.com/project/badge/Grade/9c27e94ffa3a4ee58279c36236b2b075)](https://www.codacy.com/manual/fs1194361820/sqlhelper?utm_source=github.com&utm_medium=referral&utm_content=fangjinuo/sqlhelper&utm_campaign=Badge_Grade)[![JDK](https://img.shields.io/badge/JDK-1.6+-green.svg)](https://www.oracle.com/technetwork/java/javase/downloads/index.html)
[![MyBatis](https://img.shields.io/badge/MyBatis-3.x-green.svg)](http://www.mybatis.org/mybatis-3/index.html)
[![MyBatis](https://img.shields.io/badge/MyBatisPlus-3.x-green.svg)](http://www.mybatis.org/mybatisplus-3/index.html)
[![jFinal](https://img.shields.io/badge/jFinal-3.x-green.svg)](https://github.com/jfinal/jfinal)
[![jFinal](https://img.shields.io/badge/jFinal-4.x-green.svg)](https://github.com/jfinal/jfinal)
[![EBean](https://img.shields.io/badge/Ebean-11.x-green.svg)](https://ebean.io/docs/query/sqlquery)
[![Mango](https://img.shields.io/badge/Mango-1.6.x-green.svg)](https://github.com/jfaster/mango)
[![Commons-DBUtils](https://img.shields.io/badge/Apache_Commons_DBUtils-1.7.x-green.svg)](http://commons.apache.org/proper/commons-dbutils/index.html)
[![Solon](https://img.shields.io/badge/solon-1.x-green.svg)](https://github.com/noear/solon)[![Spring-Jdbc](https://img.shields.io/badge/SpringJdbc-2.x-green.svg)](https://spring.io/projects/spring-framework)
[![Spring-Jdbc](https://img.shields.io/badge/SpringJdbc-3.x-green.svg)](https://spring.io/projects/spring-framework)
[![Spring-Jdbc](https://img.shields.io/badge/SpringJdbc-4.x-green.svg)](https://spring.io/projects/spring-framework)
[![Spring-Jdbc](https://img.shields.io/badge/SpringJdbc-5.x-green.svg)](https://spring.io/projects/spring-framework)[![SpringBoot](https://img.shields.io/badge/SpringBoot-1.x-green.svg)](https://spring.io/projects/spring-boot/)
[![SpringBoot](https://img.shields.io/badge/SpringBoot-2.x-green.svg)](https://spring.io/projects/spring-boot/)[![maven](https://img.shields.io/badge/maven-v4.0.0-green.svg)](https://search.maven.org/search?q=g:com.github.fangjinuo.sqlhelper%20AND%20v:4.0.0)
## [GitHub地址](https://github.com/fangjinuo)
## [Gitee地址](https://gitee.com/fangjinuo)
## [教程](./.wiki/index.md)# 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
### 关键特性
1. 支持 MyBatis, MyBatis-Plus, Tk.Mapper, SpringJdbc, Apache Commons-DBUtils, JFinal, EBean, Mango, Hibernate 等众多对数据库操作的框架
2. 支持 130+ 数据库(所有功能均支持,不限于分页功能), 支持的数据库列表参考: ***[here](https://github.com/f1194361820/sqlhelper/wiki/Pagination_Database)***. 如果你想了解这些数据库的排名,可以参考这里:[DB Engines](https://db-engines.com/en/ranking/relational+dbms).下面是所有支持的国产数据库:
+ 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 (优炫数据库)
3. 支持多个数据库在同一个应用中并存,且不需要做任何的区分,就能自动识别
4. 支持自动获取数据库 dialect (方言),也可以指定
5. 性能要比**Mybatis-PageHelper**更高, 因为SQL中的 limit、offset 会以占位符 '?'的形式存在,支持缓存等,总之PageHelper支持的这里都支持,PageHelper不支持的这里也支持。
6. 对于 select count语句,会自动的排除掉 order by 子句,以提升查询效率
7. 可以基于 Java SPI 规范来自定义Dialect,以此来扩展数据库
8. 分页功能支持**子查询**:mybatis, mybatis-plus, spring-jdbc, apache commons-dbutils
9. 支持 spring boot 1.x , 2.x
10. 支持 JDK6+
11. 支持 **Memory Pagination**
12. 支持 SqlSymbolMapper, 可以使用它来自动映射数据库字段、表名等
13. 支持 **Dump DDL**
14. 支持 **like parameter escape [%]** : mybatis, mybatis-plus, tk.mapper 下使用
15. 动态数据源 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 | √ |
# 分页工具使用说明
* [Quick Start](https://github.com/fangjinuo/sqlhelper/wiki/Pagination_QuickStart)
+ [MyBatis application](https://github.com/fangjinuo/sqlhelper/wiki/Pagination_QuickStart_MyBatis)
- [Installation](https://github.com/fangjinuo/sqlhelper/wiki/Pagination_QuickStart_MyBatis)
- [How To](https://github.com/fangjinuo/sqlhelper/wiki/Pagination_QuickStart_MyBatis)
- [Migrate from mybatis-pagehelper application](https://github.com/fangjinuo/sqlhelper/wiki/Pagination_QuickStart_MyBatis)
+ [SpringJDBC application](https://github.com/fangjinuo/sqlhelper/wiki/Pagination_QuickStart_SpringJDBC)
- [Installation](https://github.com/fangjinuo/sqlhelper/wiki/Pagination_QuickStart_SpringJDBC)
- [How To](https://github.com/fangjinuo/sqlhelper/wiki/Pagination_QuickStart_SpringJDBC)
+ [jFinal application](https://github.com/fangjinuo/sqlhelper/wiki/Pagination_QuickStart_jFinal)
- [Installation](https://github.com/fangjinuo/sqlhelper/wiki/Pagination_QuickStart_jFinal)
- [How To](https://github.com/fangjinuo/sqlhelper/wiki/Pagination_QuickStart_jFinal)
+ [MyBatis-Plus application](https://github.com/fangjinuo/sqlhelper/wiki/Pagination_QuickStart_MyBatis_Plus)
+ [EBean application](https://github.com/fangjinuo/sqlhelper/wiki/Pagination_QuickStart_ebean)
* Advanced Usage更多说明,参见教程:
```html
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
```yaml
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 - 开发计划
+ [ ] 通用框架
+ [X] 连接池实现
+ [X] 支持常见连接池:HikariCP, Alibaba Druid, tomcat-jdbc, dbcp2, c3p0
+ [X] 支持在配置中使用哪个连接池实现
+ [X] 支持所用连接池实现的特有配置项
+ [X] DataSource 配置
+ [X] 支持分组配置,通常一个业务群一个分组,或者一个数据库集群用一个分组
+ [X] 兼容 SpringBoot 默认 DataSource 配置
+ [X] 支持多种异构数据源
+ [X] DataSource 识别
+ [X] 提供 @DataSource 注解,可以在 method, class 级别使用
+ [X] 支持 自定义注解。
+ [X] 支持多层级 注解配置。筛选时,安装最近优先原则
+ [X] 支持自定义识别算法。例如可以基于此自行实现负载均衡,读写分离,随机等众多识别算法。
+ [X] 支持多层嵌套。
+ [X] 可自定义AOP拦截位置。
+ [ ] Router
+ [X] master, slave 识别
+ [X] 基于 readonly 确定是否必定为slave
+ [X] 基于 primary 判断
+ [X] 如果没有primary属性则 基于 name 判断
+ [X] master 路由算法
+ [X] first,即只取第一个
+ [X] slave 路由算法
+ [X] 随机路由
+ [X] 读写分离路由
+ [X] 负载均衡路由
+ [ ] 故障转移
+ [ ] 框架支持
+ [X] mybatis & spring boot 应用
+ [X] mybatis 2.x, 3x & spring boot 应用
+ [X] 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模块。# [FAQ](https://github.com/fangjinuo/sqlhelper/wiki/FAQ)
这里提供了一些常见问题,对于刚使用SQLHelper时,可能对你很有帮助# Contact
QQ 交流群: 750929088
![QQ Group](https://github.com/fangjinuo/sqlhelper/blob/master/_images/qq_group.png)## [推广](https://github.com/fangjinuo)
+ langx 系列
- [langx-js](https://github.com/fangjinuo/langx-js):TypeScript, JavaScript tools
- [langx-java](https://github.com/fangjinuo/langx-java): Java tools ,可以替换guava, apache commons-lang,io, hu-tool等
+ [easyjson](https://github.com/fangjinuo/easyjson): 一个通用的JSON库门面,可以无缝的在各个JSON库之间切换,就像slf4j那样。
+ [sqlhelper](https://github.com/fangjinuo/sqlhelper): SQL工具套件(通用分页、DDL Dump、SQLParser、URL Parser、批量操作工具等)。
+ [esmvc](https://github.com/fangjinuo/es-mvc): ElasticSearch 通用客户端,就像MyBatis Mapper那样顺滑
+ [agileway](https://github.com/fangjinuo/agileway): 提供大量的框架扩展,方便日常开发
+ [audit](https://github.com/fangjinuo/audit):通用的Java应用审计框架## 鸣谢
最后,感谢 Jetbrains 提供免费License,方便了开源项目的发展。[![Jetbrains](https://github.com/fangjinuo/sqlhelper/blob/master/_images/jetbrains.png)](https://www.jetbrains.com/zh-cn/)