#MyBatis通用Mapper3
##极其方便的使用MyBatis单表的增删改查
##支持单表操作,不支持通用的多表联合查询
##优点?
通用Mapper都可以极大的方便开发人员。可以随意的按照自己的需要选择通用方法,还可以很方便的开发自己的通用方法。
为了让您更方便的了解这通用Mapper,这里贴一段代码来看实际效果。
##通用Mapper2
目前最新的Mapper3版本改动很大,如果正在使用2.x版本,可以去看2.x版本的文档:
Mapper2.x版本首页http://git.oschina.net/free/Mapper2
如果想同时使用Mapper3和Mapper2中的EntityMapper和SqlMapper,看这里:http://git.oschina.net/free/EntityMapper
##Mapper2.x升级Mapper3注意事项
##通用Mapper3
全部针对单表操作,每个实体类都需要继承通用Mapper接口来获得通用方法。
示例代码:
CountryMapper mapper = sqlSession.getMapper(CountryMapper.class);
//查询全部
List<Country> countryList = mapper.select(new Country());
//总数
Assert.assertEquals(183, countryList.size());
//通用Example查询
Example example = new Example(Country.class);
example.createCriteria().andGreaterThan("id", 100);
countryList = mapper.selectByExample(example);
Assert.assertEquals(83, countryList.size());
//MyBatis-Generator生成的Example查询
CountryExample example2 = new CountryExample();
example2.createCriteria().andIdGreaterThan(100);
countryList = mapper.selectByExample(example2);
Assert.assertEquals(83, countryList.size());
CountryMapper代码如下:
public interface CountryMapper extends Mapper<Country> {
}
这里不说更具体的内容,如果您有兴趣,可以查看下面的项目文档
##实体类注解
从上面效果来看也能感觉出这是一种类似hibernate的用法,因此也需要实体和表对应起来,因此使用了JPA注解。更详细的内容可以看下面的项目文档。
Country代码:
public class Country {
@Id
private Integer id;
@Column
private String countryname;
private String countrycode;
//省略setter和getter方法
}
使用Mapper专用的MyBatis Generator插件 可以方便的生成这些(带注解的)实体类。
##通用Mapper支持Mybatis-3.2.4及以上版本
##更新日志
##Maven坐标以及下载地址
###测试版本3.1.3-SNAPSHOT - 2015-07-14
- 新增
MapperOnceInterceptor
拦截器,该拦截器执行后会自动卸载,以后不会再进入该方法,只需要将MapperInterceptor
替换为MapperOnceInterceptor
即可 - 由于
MapperHelper
的配置方式容易出现错误,因此从3.1.3以后废弃这种配置方法
###最新版本3.1.2 - 2015-07-14
- 解决别名时的一种特殊情况,例如
@Column(name="
desc")
的时候,就不需要自动添加别名 - 反射获取所有列名的时候,不在自动转换为大写形式,对数据库区分大小写的情况有用
###3.1.1 - 2015-07-01
- 解决
ConditionMapper
中selectByCondition
和updateByCondition
方法错误
###3.1.0 - 2015-06-10
- 基础包名从
com.github.abel533
改为tk.mybatis.mapper
- Maven的groupId改为
tk.mybatis
,artifactId为mapper
- 增加和Example功能类似的Condition查询,仅仅名字不同
- 更多详细变化请看Mapper3通用接口大全
- 关于3.0.x版本请看Mapper3.0.x
###3.0.0 - 2015-06-04
- 将
EntityMapper
和SqlMapper
移出,现在是独立项目EntityMapper - 将
Mapper<T>
全部接口方法拆分为独立接口,方便选择集成 - 增加
MySqlMapper<T>
包含批量插入和单个插入,批量插入可以回写全部id - 增加
RowBoundsMapper<T>
包含两个分页查询,可以配合PageHelper实现物理分页 - 详细变化请看Mapper3变化
- Mapper2资深用户请看Mapper3高级应用
- Mapper3通用接口大全
- 快速开发自己的通用接口
##使用Maven
###重要提示,3.1.0及以后版本的groupId修改为tk.mybatis,artifactId为mapper
<dependency>
<groupId>tk.mybatis</groupId>
<artifactId>mapper</artifactId>
<version>3.1.2</version>
</dependency>
##引入Jar包,下载地址:
https://oss.sonatype.org/content/repositories/releases/tk/mybatis/mapper
http://repo1.maven.org/maven2/tk/mybatis/mapper
由于通用Mapper依赖JPA,所以还需要下载persistence-api-1.0.jar:
http://repo1.maven.org/maven2/javax/persistence/persistence-api/1.0/
##项目文档
###通用Mapper 3
###通用Mapper 2
##作者信息
作者博客:http://blog.csdn.net/isea533
作者邮箱: [email protected]
Mybatis工具群: 211286137 (Mybatis相关工具插件等等)
推荐使用Mybatis分页插件:PageHelper分页插件