日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

mybatis-通用Mapper

發布時間:2024/4/13 编程问答 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 mybatis-通用Mapper 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

問題:當我們的表字段發生變化的時候,我們需要修改實體類和Mapper 文件定義的字段和方法。如果是增量維護,那么一個個文件去修改。如果是全量替換,我們還要去對比用MBG 生成的文件。字段變動一次就要修改一次,維護起來非常麻煩。

解決這個問題,我們有兩種思路。

第一個, 因為MyBatis 的Mapper 是支持繼承的( 見:https://github.com/mybatis/mybatis-3/issues/35 ) 。所以我們可以把我們的Mapper.xml 和Mapper 接口都分成兩個文件。一個是MBG 生成的,這部分是固定不變的。然后創建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 等標簽--><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 的文件就可以了。這么做有一個缺點,就是文件會增多。

思考:既然針對每張表生成的基本方法都是一樣的,也就是公共的方法部分代碼都是一樣的,我們能不能把這部分合并成一個文件,讓它支持泛型呢?

太聰明了,當然可以!

編寫一個支持泛型的通用接口,比如叫GPBaseMapper<T>,把實體類作為參數傳入。這個接口里面定義了大量的增刪改查的基礎方法,這些方法都是支持泛型的。

自定義的Mapper 接口繼承該通用接口, 例如BlogMapper extends GPBaseMapper<Blog>,自動獲得對實體類的操作方法。遇到沒有的方法,我們依然可以在我們自己的Mapper 里面編寫。

我們能想到的解決方案,早就有人做了這個事了,這個東西就叫做通用Mapper。

https://github.com/abel533/Mapper/wiki

用途:主要解決單表的增刪改查問題,并不適用于多表關聯查詢的場景。

除了配置文件變動的問題之外,通用Mapper 還可以解決:

1、每個Mapper 接口中大量的重復方法的定義;

2、屏蔽數據庫的差異;

3、提供批量操作的方法;

4、實現分頁。

通用Mapper 和PageHelper 作者是同一個人(劉增輝)。

使用方式:在Spring 中使用時,引入jar 包,替換applicationContext.xml 中的sqlSessionFactory 和configure。

<bean class="tk.mybatis.spring.mapper.MapperScannerConfigurer"><property name="basePackage" value="com.leon.crud.dao"/> </bean>

?

總結

以上是生活随笔為你收集整理的mybatis-通用Mapper的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。