Mybatis的類型轉(zhuǎn)換接口TypeHandler
前言:
mybatis可以實(shí)現(xiàn)jdbc類型和java類型之間的轉(zhuǎn)換,具體來說有一個(gè)類型轉(zhuǎn)換器的接口
類型處理器接口TypeHandler
public interface TypeHandler<T> {
void setParameter(PreparedStatement ps, int i, T parameter, JdbcType jdbcType) throws SQLException;
/**
* @param columnName Colunm name, when configuration <code>useColumnLabel</code> is <code>false</code>
*/
T getResult(ResultSet rs, String columnName) throws SQLException;
T getResult(ResultSet rs, int columnIndex) throws SQLException;
T getResult(CallableStatement cs, int columnIndex) throws SQLException;
}類型處理器BaseTypeHandler
jdbc類型轉(zhuǎn)為java類型
BaseTypeHandler實(shí)現(xiàn)了TypeHandler接口,實(shí)現(xiàn)了setParameter()方法:
@Override
public void setParameter(PreparedStatement ps, int i, T parameter, JdbcType jdbcType) throws SQLException {
if (parameter == null) {
if (jdbcType == null) {
throw new TypeException("JDBC requires that the JdbcType must be specified for all nullable parameters.");
}
try {
ps.setNull(i, jdbcType.TYPE_CODE);
} catch (SQLException e) {
throw new TypeException("Error setting null for parameter #" + i + " with JdbcType " + jdbcType + " . "
+ "Try setting a different JdbcType for this parameter or a different jdbcTypeForNull configuration property. "
+ "Cause: " + e, e);
}
} else {
try {
setNonNullParameter(ps, i, parameter, jdbcType);
} catch (Exception e) {
throw new TypeException("Error setting non null for parameter #" + i + " with JdbcType " + jdbcType + " . "
+ "Try setting a different JdbcType for this parameter or a different configuration property. "
+ "Cause: " + e, e);
}
}
}這個(gè)方法中就是設(shè)置PreparedStatement的參數(shù),也是參數(shù)綁定,將jdbcType轉(zhuǎn)為Java類型,setNonNullParameter是抽象方法,根據(jù)不同的參數(shù)類型有不同的類實(shí)現(xiàn)了這個(gè)方法,比如
LongTypeHandler實(shí)現(xiàn)的setNonNullParameter()方法:
@Override
public void setNonNullParameter(PreparedStatement ps, int i, Long parameter, JdbcType jdbcType)
throws SQLException {
ps.setLong(i, parameter);
}java類型轉(zhuǎn)為jdbc類型
BaseTypeHandler的getResult()方法:
@Override
public T getResult(CallableStatement cs, int columnIndex) throws SQLException {
try {
return getNullableResult(cs, columnIndex);
} catch (Exception e) {
throw new ResultMapException("Error attempting to get column #" + columnIndex + " from callable statement. Cause: " + e, e);
}
}方法也比較簡(jiǎn)單,直接調(diào)用了getNullableResult抽象類,功能就是從ResultSet中獲取數(shù)據(jù),把Java類型轉(zhuǎn)換為JdbcType類型,比如LongTypeHandler實(shí)現(xiàn)的getNullableResult():
@Override
public Long getNullableResult(ResultSet rs, String columnName)
throws SQLException {
long result = rs.getLong(columnName);
return result == 0 && rs.wasNull() ? null : result;
}通過源碼分析我們知道了TypeHandler接口的作用就是用來實(shí)現(xiàn)類型轉(zhuǎn)換的,mybatis在初始化的時(shí)候就獲取TypeHandler,然后創(chuàng)建TypeHandler實(shí)例注冊(cè)到TypeHandlerRegistry中,由TypeHandlerRegistry來進(jìn)行管理這些實(shí)例,下篇文章中我們介紹一下TypeHandlerRegistry這個(gè)類
總結(jié)
文章講了Mybatis的類型轉(zhuǎn)換接口TypeHandler和它的實(shí)現(xiàn)類BaseTypeHandler,類型轉(zhuǎn)換接口顯然就是實(shí)現(xiàn)jdbc類型和java類型之間的轉(zhuǎn)換,同時(shí)分析了BaseTypeHandler的setParameter()方法和getResult()方法,getNullableResult是抽象類,具體方法由其他實(shí)現(xiàn)類進(jìn)行實(shí)現(xiàn)。
到此這篇關(guān)于Mybatis的類型轉(zhuǎn)換接口TypeHandler的文章就介紹到這了,更多相關(guān)Mybatis類型轉(zhuǎn)換內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Mybatis的TypeHandler實(shí)現(xiàn)數(shù)據(jù)加解密詳解
- Mybatis基于TypeHandler實(shí)現(xiàn)敏感數(shù)據(jù)加密
- MyBatis中的自定義TypeHandler詳解
- MyBatis?typeHandler接口的定義和使用
- Mybatis之類型處理器TypeHandler的作用與自定義方式
- mybatis之BaseTypeHandler用法解讀
- mybatis-plus之自動(dòng)映射字段(typeHandler)的注意點(diǎn)及說明
- Mybatis?TypeHandler接口及繼承關(guān)系示例解析
- Mybatis中TypeHandler使用小結(jié)
相關(guān)文章
SpringBoot部署在tomcat容器中運(yùn)行的部署方法
這篇文章主要介紹了SpringBoot部署在tomcat容器中運(yùn)行的部署方法,需要的朋友可以參考下2018-10-10
Java類的序列化版本唯一標(biāo)識(shí)符serialVersionUID使用
serialVersionUID是一個(gè)類的序列化版本唯一標(biāo)識(shí)符,用于確保在反序列化過程中類的實(shí)例與序列化文件中的類版本相匹配,它在版本兼容性和安全性方面起著關(guān)鍵作用2025-01-01
SpringBoot3.0自定stater模塊的操作流程(chatGPT提供的49種場(chǎng)景)
SpringBoot3.0發(fā)布等重磅陸消息續(xù)進(jìn)入大家的視線,而本文作者將以技術(shù)整合的角度,帶大家把最火的兩個(gè)技術(shù)整合在一起,通過本文學(xué)習(xí)你將熟悉SpringBoot3.0自定stater模塊的操作流程,并熟悉OpenAi為chatGPT提供的49種場(chǎng)景,感興趣的朋友一起看看吧2022-12-12
使用Feign調(diào)用注解組件(實(shí)現(xiàn)字段賦值功能)
這篇文章主要介紹了使用Feign調(diào)用注解組件(實(shí)現(xiàn)字段賦值功能),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
SpringBoot實(shí)現(xiàn)驗(yàn)證碼的案例分享
驗(yàn)證碼可以有效防止其他人對(duì)某一個(gè)特定的注冊(cè)用戶用特定的程序,破解方式進(jìn)行不斷的登錄嘗試,我們其實(shí)很經(jīng)常看到,登錄一些網(wǎng)站其實(shí)是需要驗(yàn)證碼的,所以本文給大家分享了SpringBoot實(shí)現(xiàn)驗(yàn)證碼的案例,需要的朋友可以參考下2024-11-11

