mybatis-通用Mapper
問題:當(dāng)我們的表字段發(fā)生變化的時候,我們需要修改實體類和Mapper 文件定義的字段和方法。如果是增量維護,那么一個個文件去修改。如果是全量替換,我們還要去對比用MBG 生成的文件。字段變動一次就要修改一次,維護起來非常麻煩。
解決這個問題,我們有兩種思路。
第一個, 因為MyBatis 的Mapper 是支持繼承的( 見:https://github.com/mybatis/mybatis-3/issues/35 ) 。所以我們可以把我們的Mapper.xml 和Mapper 接口都分成兩個文件。一個是MBG 生成的,這部分是固定不變的。然后創(chuàng)建DAO 類繼承生成的接口,變化的部分就在DAO 里面維護。
mybatis-standalone 工程:
public interface BlogMapperExt extends BlogMapper {public Blog selectBlogByName(String name); } <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.leon.mapper.BlogMapperExt"><!-- 只能繼承statement,不能繼承sql、resultMap 等標(biāo)簽--><resultMap id="BaseResultMap" type="com.leon.domain.Blog"><id column="bid" property="bid" jdbcType="INTEGER"/><result column="name" property="name" jdbcType="VARCHAR"/><result column="author_id" property="authorId" jdbcType="INTEGER"/></resultMap><!-- 在parent xml 和child xml 的statement id 相同的情況下,會使用child xml 的statementid --><select id="selectBlogByName" resultMap="BaseResultMap" statementType="PREPARED">select * from blog where name = #{name}</select> </mapper>mybatis-config.xml 里面也要掃描:
<mappers><mapper resource="BlogMapper.xml"/><mapper resource="BlogMapperExt.xml"/> </mappers>所以以后只要修改Ext 的文件就可以了。這么做有一個缺點,就是文件會增多。
思考:既然針對每張表生成的基本方法都是一樣的,也就是公共的方法部分代碼都是一樣的,我們能不能把這部分合并成一個文件,讓它支持泛型呢?
太聰明了,當(dāng)然可以!
編寫一個支持泛型的通用接口,比如叫GPBaseMapper<T>,把實體類作為參數(shù)傳入。這個接口里面定義了大量的增刪改查的基礎(chǔ)方法,這些方法都是支持泛型的。
自定義的Mapper 接口繼承該通用接口, 例如BlogMapper extends GPBaseMapper<Blog>,自動獲得對實體類的操作方法。遇到?jīng)]有的方法,我們依然可以在我們自己的Mapper 里面編寫。
我們能想到的解決方案,早就有人做了這個事了,這個東西就叫做通用Mapper。
https://github.com/abel533/Mapper/wiki
用途:主要解決單表的增刪改查問題,并不適用于多表關(guān)聯(lián)查詢的場景。
除了配置文件變動的問題之外,通用Mapper 還可以解決:
1、每個Mapper 接口中大量的重復(fù)方法的定義;
2、屏蔽數(shù)據(jù)庫的差異;
3、提供批量操作的方法;
4、實現(xiàn)分頁。
通用Mapper 和PageHelper 作者是同一個人(劉增輝)。
使用方式:在Spring 中使用時,引入jar 包,替換applicationContext.xml 中的sqlSessionFactory 和configure。
<bean class="tk.mybatis.spring.mapper.MapperScannerConfigurer"><property name="basePackage" value="com.leon.crud.dao"/> </bean>?
總結(jié)
以上是生活随笔為你收集整理的mybatis-通用Mapper的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: mybatis-物理翻页
- 下一篇: mybatis-MyBatis-Plus