Mybatis的類型轉(zhuǎn)換接口TypeHandler
前言:
mybatis可以實現(xiàn)jdbc類型和java類型之間的轉(zhuǎn)換,具體來說有一個類型轉(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實現(xiàn)了TypeHandler接口,實現(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);
}
}
}這個方法中就是設(shè)置PreparedStatement的參數(shù),也是參數(shù)綁定,將jdbcType轉(zhuǎn)為Java類型,setNonNullParameter是抽象方法,根據(jù)不同的參數(shù)類型有不同的類實現(xiàn)了這個方法,比如
LongTypeHandler實現(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);
}
}方法也比較簡單,直接調(diào)用了getNullableResult抽象類,功能就是從ResultSet中獲取數(shù)據(jù),把Java類型轉(zhuǎn)換為JdbcType類型,比如LongTypeHandler實現(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接口的作用就是用來實現(xiàn)類型轉(zhuǎn)換的,mybatis在初始化的時候就獲取TypeHandler,然后創(chuàng)建TypeHandler實例注冊到TypeHandlerRegistry中,由TypeHandlerRegistry來進行管理這些實例,下篇文章中我們介紹一下TypeHandlerRegistry這個類
總結(jié)
文章講了Mybatis的類型轉(zhuǎn)換接口TypeHandler和它的實現(xiàn)類BaseTypeHandler,類型轉(zhuǎn)換接口顯然就是實現(xiàn)jdbc類型和java類型之間的轉(zhuǎn)換,同時分析了BaseTypeHandler的setParameter()方法和getResult()方法,getNullableResult是抽象類,具體方法由其他實現(xiàn)類進行實現(xiàn)。
到此這篇關(guān)于Mybatis的類型轉(zhuǎn)換接口TypeHandler的文章就介紹到這了,更多相關(guān)Mybatis類型轉(zhuǎn)換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
- Mybatis的TypeHandler實現(xiàn)數(shù)據(jù)加解密詳解
- Mybatis基于TypeHandler實現(xiàn)敏感數(shù)據(jù)加密
- MyBatis中的自定義TypeHandler詳解
- MyBatis?typeHandler接口的定義和使用
- Mybatis之類型處理器TypeHandler的作用與自定義方式
- mybatis之BaseTypeHandler用法解讀
- mybatis-plus之自動映射字段(typeHandler)的注意點及說明
- Mybatis?TypeHandler接口及繼承關(guān)系示例解析
- Mybatis中TypeHandler使用小結(jié)
相關(guān)文章
InteliJ IDEA 設(shè)置eclipse快捷鍵 的圖文教程
本文通過圖文并茂的形式給大家介紹了InteliJ IDEA 設(shè)置eclipse快捷鍵 ,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下2018-06-06
調(diào)用Mybatis?plus中的saveBatch方法報找不到表的問題
在用Mybatis plus開發(fā)的項目中,用自帶的API批量保存的方法saveBatch操作時,發(fā)現(xiàn)報沒有找到表的錯誤,本文就來詳細的介紹一下解決方法,感興趣的可以了解一下2024-03-03
Java進階學(xué)習(xí):網(wǎng)絡(luò)服務(wù)器編程
Java進階學(xué)習(xí):網(wǎng)絡(luò)服務(wù)器編程...2006-12-12
javaweb Servlet開發(fā)總結(jié)(一)
Servlet是sun公司提供的一門用于開發(fā)動態(tài)web資源的技術(shù)。這篇文章主要介紹了javaweb Servlet開發(fā)的第一篇,感興趣的小伙伴們可以參考一下2016-05-05

