mybatis之BaseTypeHandler用法解讀
BaseTypeHandler用法
BaseTypeHandler 是個(gè)抽象類(lèi),需要子類(lèi)去實(shí)現(xiàn)其定義的 4 個(gè)抽象方法,而它本身實(shí)現(xiàn)了 typeHandler 接口的 4 個(gè)方法。
可以對(duì)數(shù)據(jù)保存與查詢(xún)時(shí)做出相應(yīng)處理,類(lèi)似操作數(shù)據(jù)庫(kù)之間的一個(gè)攔截器
舉栗子:把集合類(lèi)型當(dāng)string存起來(lái),讀取的時(shí)候映射為list集合
首先自定義handler 繼承BaseTypeHandler重寫(xiě)他里邊的四個(gè)方法
public abstract void setNonNullParameter(PreparedStatement var1, int var2, T var3, JdbcType var4) throws SQLException; public abstract T getNullableResult(ResultSet var1, String var2) throws SQLException; public abstract T getNullableResult(ResultSet var1, int var2) throws SQLException; public abstract T getNullableResult(CallableStatement var1, int var2) throws SQLException;
代碼如下
public class ListToStringHandler extends BaseTypeHandler<List> {
@Override
public void setNonNullParameter(PreparedStatement preparedStatement, int i, List list, JdbcType jdbcType) throws SQLException {
preparedStatement.setString(i, JSON.toJSONString(list));
}
@Override
public List getNullableResult(ResultSet resultSet, String s) throws SQLException {
return JSONArray.parseArray(resultSet.getString(s));
}
@Override
public List getNullableResult(ResultSet resultSet, int i) throws SQLException {
return JSONArray.parseArray(resultSet.getString(i));
}
@Override
public List getNullableResult(CallableStatement callableStatement, int i) throws SQLException {
return JSONArray.parseArray(callableStatement.getString(i));
}
}映射操作
mybaits-plus 方式
bean上添加注解
@TableName(autoResultMap = true)
映射字段上添加如下注解,指定自定義的handler
@TableField(jdbcType = JdbcType.VARCHAR, typeHandler = ListToStringHandler.class)
mybaits的方式
<resultMap> 標(biāo)簽內(nèi) 映射字段的handler 指定自定義的handler即可,保存的時(shí)候也要指定。
測(cè)試


![]()
這只是其一種簡(jiǎn)單的用法,其他的比如加密解密也適用。
通過(guò)BaseTypeHandler從mysql數(shù)據(jù)庫(kù)存取json字符串
在mysql的使用過(guò)程中,我們經(jīng)常會(huì)將一些json串存入mysql當(dāng)中,如下json串
{
? ? "params":[
? ? ? ? {
? ? ? ? ? ? "name":"zl",
? ? ? ? ? ? "age":18,
? ? ? ? ? ? "createTime":"2020-06-19 09:28:38",
? ? ? ? ? ? "modifyTime":"2020-06-19 09:29:07"
? ? ? ? }
? ? ],
? ? "paramsTypes":[
? ? ? ? "com.zl.platform.student"
? ? ]
}對(duì)于這種數(shù)據(jù)在mybatis的存取過(guò)程需要一些特殊的處理,我們可以通過(guò)繼承mybatis的org.apache.ibatis.type.BaseTypeHandler來(lái)實(shí)現(xiàn)。
首先我們需要完成一個(gè)工具類(lèi)
import com.alibaba.fastjson.JSON;
import org.apache.ibatis.type.BaseTypeHandler;
import org.apache.ibatis.type.JdbcType;
import java.sql.CallableStatement;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.SQLException;
/**
?* @Author: zl
?*/
public class JsonTypeHandler<T> extends BaseTypeHandler<T> {
? ? private Class<T> type;
? ? public JsonTypeHandler(Class<T> type) {
? ? ? ? if (type == null) {
? ? ? ? ? ? throw new IllegalArgumentException("Type argument cannot be null");
? ? ? ? }
? ? ? ? this.type = type;
? ? }
? ? @Override
? ? public void setNonNullParameter(PreparedStatement ps, int i, Object parameter,
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? JdbcType jdbcType) throws SQLException {
? ? ? ? ps.setString(i, JSON.toJSONString(parameter));
? ? }
? ? @Override
? ? public T getNullableResult(ResultSet rs, String columnName)
? ? ? ? ? ? throws SQLException {
? ? ? ? return JSON.parseObject(rs.getString(columnName), type);
? ? }
? ? @Override
? ? public T getNullableResult(ResultSet rs, int columnIndex) throws SQLException {
? ? ? ? return JSON.parseObject(rs.getString(columnIndex), type);
? ? }
? ? @Override
? ? public T getNullableResult(CallableStatement cs, int columnIndex)
? ? ? ? ? ? throws SQLException {
? ? ? ? return JSON.parseObject(cs.getString(columnIndex), type);
? ? }
}然后在mybatis中對(duì)需要使用json格式的字段引用這個(gè)方法
? ? <resultMap id="BaseResultMap" type="com.zl.platform.entity.demo.DubboControllerInfo">
? ? ? ? <id column="id" property="id" />
? ? ? ? <result column="department" property="department" />
? ? ? ? <result column="case_name" property="caseName"/>
? ? ? ? <result column="author" property="author" />
? ? ? ? <result column="service_name" property="serviceName" />
? ? ? ? <result column="method_name" property="methodName" />
? ? ? ? <result column="dubbo_params" property="dubboParams" typeHandler="com.zl.platform.utils.JsonTypeHandler"/>
? ? ? ? <result column="create_time" property="createTime" />
? ? ? ? <result column="update_time" property="updateTime" />
? ? </resultMap>
? ??
? ? <insert id="insertDubboInfo" ?parameterType="com.zl.platform.entity.demo.DubboControllerInfo">
? ? ? insert into dubbo_controller_info (department, author, service_name,
? ? ? method_name, dubbo_params,create_time, update_time)
? ? ? VALUES (#{department},#{author},#{serviceName},#{methodName},#{dubboParams,typeHandler=com.zl.platform.utils.JsonTypeHandler},
? ? ? ?#{createTime},#{updateTime})
? ? </insert>
? ? <select id="selectAll" resultMap="BaseResultMap">
? ? ? ? select * from dubbo_controller_info
? ? </select>總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
- mybatis-plus之自動(dòng)映射字段(typeHandler)的注意點(diǎn)及說(shuō)明
- MyBatisPlus?TypeHandler自定義字段類(lèi)型轉(zhuǎn)換Handler
- mybatis TypeHandler注入spring的依賴(lài)方式
- MybatisPlus如何自定義TypeHandler映射JSON類(lèi)型為L(zhǎng)ist
- Mybatis自定義TypeHandler解決特殊類(lèi)型轉(zhuǎn)換問(wèn)題詳解
- MyBatis自定義typeHandler的完整實(shí)例
- Mybatis實(shí)現(xiàn)自定義類(lèi)型轉(zhuǎn)換器TypeHandler的方法
- Mybatis實(shí)現(xiàn)自定義的typehandler三步曲
- 微服務(wù)mybatis?typehandler使用詳解(就這一篇夠了)
相關(guān)文章
java中Lambda常用場(chǎng)景代碼實(shí)例
這篇文章主要介紹了java中Lambda常用場(chǎng)景,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
Java編程調(diào)用微信接口實(shí)現(xiàn)圖文信息推送功能
這篇文章主要介紹了Java編程調(diào)用微信接口實(shí)現(xiàn)圖文信息等推送功能,涉及java微信圖文信息推送接口調(diào)用及相關(guān)文件、字符串編碼轉(zhuǎn)換相關(guān)操作技巧,需要的朋友可以參考下2017-08-08
Java 8 中 Map 騷操作之 merge() 的使用方法
本文簡(jiǎn)單介紹了一下Map.merge()的方法,除此之外,Java 8 中的HashMap實(shí)現(xiàn)方法使用了TreeNode和 紅黑樹(shù),原理很相似,今天通過(guò)本文給大家介紹Java 8 中 Map 騷操作之 merge() 的用法 ,需要的朋友參考下吧2021-07-07
深入解讀Java代碼組織中的package包結(jié)構(gòu)
這篇文章主要介紹了Java代碼組織中的package包結(jié)構(gòu),是Java入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2016-03-03
Java Socket編程(四) 重復(fù)和并發(fā)服務(wù)器
Java Socket編程(四) 重復(fù)和并發(fā)服務(wù)器...2006-12-12
對(duì)象存儲(chǔ)服務(wù)MinIO快速入門(mén)(集成項(xiàng)目的詳細(xì)過(guò)程)
MinIO是一個(gè)開(kāi)源的對(duì)象存儲(chǔ)服務(wù),支持多種操作系統(tǒng),配置簡(jiǎn)單且性能高,它使用糾刪碼進(jìn)行數(shù)據(jù)保護(hù),可以容忍硬件故障,MinIO支持多種語(yǔ)言的SDK和豐富的API,本文介紹對(duì)象存儲(chǔ)服務(wù)MinIO快速入門(mén),感興趣的朋友一起看看吧2025-03-03
Java中的stream流的概念解析及實(shí)際運(yùn)用總結(jié)
流是指?jìng)鬏敃r(shí)的數(shù)據(jù),Java為流準(zhǔn)備了很多內(nèi)置類(lèi),尤其是IO輸入輸出流非常常用,這里我們來(lái)看一下Java中的stream流的概念解析及實(shí)際運(yùn)用總結(jié)2016-06-06
java 用redisTemplate 的 Operations存取list集合操作
這篇文章主要介紹了java 用redisTemplate 的 Operations存取list集合操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-08-08

