ibit-mybatis 2.x 介绍
原文链接:ibit-mybatis 2.x 介绍
概述
ibit-mybatis 是一个 Mybatis 的增强工具,在 Mybatis 的基础上增加了新的特性与功能,志在简化开发流程、提高开发效率。
特性
- 无侵入,引入
ibit-mybatis对现有工程不会产生影响。 - 无 xml 配置,基于注解的方式实现
- 灵活的CRUD(增、删、改、查)操作,Mapper,支持常用的单表CRUD操作,更有强大的SQL构造器(sql-builder),满足更为复杂的操作(如聚合函数、分组、连表、分页),为了让sql-builder更好的支持 ibit-mybatis,从 ibit-mybatis 2.0 开始,sql-builder 合并到 ibit-mybatis 中。
- 内置代码生成器(ibit-mybatis-generator),指定数据库表,自动生成Mapper(无主键、单主键和多主键 Mapper)、Entity、Properties等基础类,减少重复或者相似代码编写。
- 扩展支持,数据脱敏(后续支持)
sql-builder描述
sql-builder定义动态SQL的生成规则,用来实现单表的CRUD操作。
核心 sql 接口
详细 api 文档参考:ibit-mybatis 2.x API 文档
| 说明 | 接口 |
|---|---|
| 搜索 | QuerySql |
| 计数 | CountSql |
| 删除 | DeleteSql |
| 插入 | InsertSql |
| 更新 | UpdateSql |
sql 接口支持
不同类型的 sql, 其语句的约束不一样,下表列举所有的语句支持。
| 接口 | 支持方法 | 说明 |
|---|---|---|
| ColumnSupport | column columnPo | SELECT column1[, column2...] 语句 |
| DeleteSupport | delete | DELETE t1.* 语句 |
| DistinctSupport | distinct | DISTINCT 语句 |
| FromSupport | from | FROM table1 t1[, table2 t2...] 语句 |
| GroupBySupport | groupBy | GROUP BY t1.column1[, t2.column2, ...]语句 |
| HavingSupport | having andHaving orHaving | HAVING语句 |
| InsertTableSupport | insert | INSERT INTO table1 t1 语句, t1表示 "表别名" |
| JoinOnSupport | joinOn leftJoinOn rightJoinOn fullJoinOn innerJoinOn complexLeftJoinOn complexRightJoinOn complexFullJoinOn complexInnerJoinOn | [LEFT\|RIGHT\|FULL\|INNER] JOIN ON语句 |
| LimitSupport | limit | LIMIT #{start}, #{limit}语句 |
| OrderBySupport | orderBy | ORDER BY 语句 |
| SetSupport | set | SET 条件语句 |
| UpdateTableSupport | update | UPDATE table1 t1[, table2 t2...]语句,t1,t2表示"表别名" |
| ValuesSupport | values | (column1, column2, ...) VALUES(?, ?, ...)语句 |
| WhereSupport | where andWhere orWhere | WHERE 语句 |
sql 工厂类
工厂类:tech.ibit.mybatis.sqlbuilder.SqlFactory,一般不直接使用,继承 RawMapper 的 Mapper 可直接创建 QuerySql、CountSql、DeleteSql、InsertSql 和 UpdateSql 对应实例。
Mapper 说明
Mapper 基础支持
ibit-mybatis 定义了 4 种 Mapper,分别是 RawMapper,NoIdMapper,SingleIdMapper,MultipleIdMapper。以下分别说明。
| Mapper 类型 | 父接口 | 说明 |
|---|---|---|
| RawMapper | / | 定义最原始的增、删、改、查和 Sql 实例创建 |
| NoIdMapper | RawMapper | 扩展无主键表的增 |
| SingleIdMapper | NoIdMapper | 扩展单主键表的根据id增、删、改、查 |
| MultipleIdMapper | NoIdMapper | 扩展多主键表的根据id增、删、改、查 |
使用 ibit-mybatis-generator 2.x 版本,会根据表主键数量,继承不同的 Mapper。
Mapper 结合 Sql 自定义增、删、改、查
| Mapper 创建 Sql 实例方法 | 实例类型 | 实例执行方法说明 |
|---|---|---|
| createQuery | QuerySql | executeQueryPage:查询(包含分页信息) executeQuery:查询列表 executeQueryOne:查询单条 executeQueryDefaultPage:查询基本类型(包含分页信息) executeQueryDefault:查询基本类型 |
| createCount | CountSql | executeCount:计数 |
| createDelete | DeleteSql | executeDelete:执行删除 |
| createInsert | InsertSql | executeInsert:执行插入 executeInsertWithGenerateKeys:执行插入并生成主键 |
| createUpdate | UpdateSql | executeUpdate:执行更新 |
自定义查询例子:
public User getByUsername(String username) {
if (StringUtils.isBlank(username)) {
return null;
}
return mapper
.createQuery()
.columnPo(User.class)
.from(UserProperties.TABLE)
.andWhere(UserProperties.username.eq(username))
.limit(1)
.executeQueryOne();
}
用法
相关引用
Gradle
compile 'tech.ibit:ibit-mybatis:${lastest}'
Maven
<dependency>
<groupId>tech.ibit</groupId>
<artifactId>ibit-mybatis</artifactId>
<version>${latest}</version>
</dependency>
说明: 将 "${latest}" 替换成 2.0 以上版本。
配置说明
需要将 Mybatis Configuration 的 mapUnderscoreToCamelCase 的值设置为 true。
方式1:使用 mybatis-config.xml
<configuration>
<settings>
<setting name="mapUnderscoreToCamelCase" value="true"/>
</settings>
</configuration>
方式2:java 代码方式
Configuration configuration = new Configuration(environment);
configuration.setMapUnderscoreToCamelCase(true);
方式3:使用了 mybatis-spring-boot-starter,修改配置如下
# 字段映射驼峰
mybatis.configuration.map-underscore-to-camel-case=true
其他说明
ibit-mybatis 定义了枚举类型(CommonEnum,枚举-Integer转换),其TypeHandler为 CommonEnumTypeHandler。
如果使用 CommonEnum 作为系统通用枚举类,则需要做以下改造。
a. 新的枚举需要实现CommonEnum#getValue方法。
b. SqlProvider 需要做配置
SqlProvider.setValueFormatter(new LinkedHashMap<Class, Function<Object, Object>>() {{
put(tech.ibit.mybatis.CommonEnum.class, o -> ((tech.ibit.mybatis.CommonEnum) o).getValue());
}});
c. 修改默认的枚举 TypeHandler
方式1:使用 mybatis-config.xml
<configuration>
<settings>
<setting name="defaultEnumTypeHandler" value="tech.ibit.mybatis.CommonEnumTypeHandler"/>
</settings>
</configuration>
方式2:java 代码方式
Configuration configuration = new Configuration(environment);
configuration.setDefaultEnumTypeHandler(tech.ibit.mybatis.CommonEnumTypeHandler.class);
方式3:使用了 mybatis-spring-boot-starter,修改配置如下
# 指定默认的枚举处理类
mybatis.configuration.default-enum-type-handler=tech.ibit.mybatis.CommonEnumTypeHandler
相关项目项目
- 代码生成:ibit-mybatis-generator
- web启动项目:ibit-springboot-web-starter
- web脚手架:ibit-springboot-web-starter-archetype
公众号
喜欢我的文章,请关注公众号

ibit-mybatis 2.x 介绍的更多相关文章
- MyBatis注解Annotation介绍及Demo
MyBatis注解Annotation介绍及Demo 2014-04-21 17:09:55 标签:Mybatis Annotation 注解 ResultMap SqlBuilder 原创作品,允 ...
- 一、mybatis的插件介绍
摘自:https://www.cnblogs.com/qm-article/p/11785350.html mybatis的插件机制 一.mybatis的插件介绍 关于mybatis的插件,我想大 ...
- Mybatis通用Mapper介绍和使用
Mybatis通用Mapper介绍与使用 前言 使用Mybatis的开发者,大多数都会遇到一个问题,就是要写大量的SQL在xml文件中,除了特殊的业务逻辑SQL之外,还有大量结构类似的增删改查SQL. ...
- Mybatis拦截器介绍
拦截器的一个作用就是我们可以拦截某些方法的调用,我们可以选择在这些被拦截的方法执行前后加上某些逻辑,也可以在执行这些被拦截的方法时执行自己的逻辑而不再执行被拦截的方法.Mybatis拦截器设计的一个初 ...
- Mybatis(一)入门介绍
一.MyBatis的发展 MyBatis 是apache的一个开源项目iBatis, 2010年这个项目由apache software foundation迁移到google code, 并且改名M ...
- 详解Mybatis通用Mapper介绍与使用
使用Mybatis的开发者,大多数都会遇到一个问题,就是要写大量的SQL在xml文件中,除了特殊的业务逻辑SQL之外,还有大量结构类似的增删改查SQL.而且,当数据库表结构改动时,对应的所有SQL以及 ...
- MyBatis(1)优点&介绍&工程
本次全部学习内容:MyBatisLearning 一:jabc的相关说明: jdbc编程步骤: 加载数据库驱动 创建并获取数据库链接 创建jdbc statement对象 设置sql语句 设置sql语 ...
- Mybatis拦截器介绍及分页插件
1.1 目录 1.1 目录 1.2 前言 1.3 Interceptor接口 1.4 注册拦截器 1.5 Mybatis可拦截的方法 1.6 利用拦截器进行分页 1.2 前言 拦截器的一 ...
- jdbc、Mybatis、Hibernate介绍(非原创)
文章大纲 一.jdbc介绍二.Mybatis介绍三.Hibernate介绍四.jdbc.Mybatis.Hibernate比较五.参考文章 一.jdbc介绍 1. jdbc编程步骤 (1)加载数据 ...
- MyBatis注解Annotation介绍及Demo(转)
MyBatis可以利用SQL映射文件来配置,也可以利用Annotation来设置.MyBatis提供的一些基本注解如下表所示. 注解 目标 相应的XML 描述 @CacheNamespace 类 &l ...
随机推荐
- Java实现蓝桥杯算法提高 哥德巴赫猜想
试题 算法提高 哥德巴赫猜想 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 根据所给函数(判断一个整数是否是素数),然后依托该函数,将输入N内的偶数(6-N),输出为两个素数之和( ...
- Java实现 LeetCode 151 翻转字符串里的单词
151. 翻转字符串里的单词 给定一个字符串,逐个翻转字符串中的每个单词. 示例 1: 输入: "the sky is blue" 输出: "blue is sky th ...
- java实现古堡算式
** 古堡算式** 福尔摩斯到某古堡探险,看到门上写着一个奇怪的算式: ABCDE * ? = EDCBA 他对华生说:"ABCDE应该代表不同的数字,问号也代表某个数字!" 华生 ...
- Java实现第八届蓝桥杯包子凑数
包子凑数 题目描述 小明几乎每天早晨都会在一家包子铺吃早餐.他发现这家包子铺有N种蒸笼,其中第i种蒸笼恰好能放Ai个包子.每种蒸笼都有非常多笼,可以认为是无限笼. 每当有顾客想买X个包子,卖包子的大叔 ...
- MongoDB知识点总结
一:MongoDB 概述 一.NoSQL 简介 1. 概念:NoSQL(Not Only SQL的缩写),指的是非关系型数据库,是对不同于传统的关系型数据库的数据库管理系统的统称.用于超大规模数 ...
- php 常用的redis操作语法
String 类型操作 string是redis最基本的类型,而且string类型是二进制安全的.意思是redis的string可以包含任何数据.比如jpg图片或者序列化的对象 $redis-> ...
- MongoDB 基础知识学习笔记
注意:本文假设您已经安装好 MongoDB 数据库并启动它了. 连接 MongoDB.数据库操作.集合操作 连接 MongoDB mongo ip:port/dbName -u username -p ...
- CocosCreator实现微信排行榜
1. 概述 不管是在现实生活还是当今游戏中,各式各样的排名层出不穷.如果我们做好一款游戏,却没有实现排行榜,一定是不完美的.排行榜不仅是玩家了解自己实力的途径,也是游戏运营刺激用户留存的一种途径.在微 ...
- c常用函数-sizeof
sizeof 函数用来返回指定表达式.变量或指定数据类型在内存中所占有的字节数 接下来分析sizeof的计算过程: "abcde"是字符串,考虑到系统自动添加了结束符"\ ...
- 兄弟打印机MFC代码示范
m_strModel.LoadString(IDS_MODEL_STRING); //IDS_MODEL_STRING,字符串控件的ID,资源视图-String Table里面设置 m_strSour ...