Mybatis實(shí)現(xiàn)自定義的typehandler三步曲
第一步實(shí)現(xiàn)接口TypeHandler<T>
@MappedJdbcTypes(JdbcType.TIMESTAMP)//此處如果不使用該注解,在myabtis-config.xml中注冊(cè)該typehandler的時(shí)候需要寫(xiě)明jdbctype="TIMESTAMP"
@MappedTypes(DateTime.class)//此處如果不使用該注解,在myabtis-config.xml中注冊(cè)該typehandler的時(shí)候需要寫(xiě)明javatype="com.sinosoft.sysframework.common.datatype.DateTime"
public class DateTimeHandler implements TypeHandler<DateTime> {
第二步注冊(cè)typehandler
注冊(cè)方式有兩種
一種是單個(gè)注冊(cè)
<typeHandlers> <typeHandler handler="com.***.DateaTimeTypeHandler" javaType="[Ljava.lang.String;" jdbcType="VARCHAR"/> </typeHandlers>
一種是批量注冊(cè)
<mappers> <mapper resource="com/tiantian/mybatis/mapper/UserMapper.xml"/> <package name="com.tiantian.mybatis.mapperinterface"/> </mappers>
如果使用第二種注冊(cè)方式,jdbctype和javatype的聲明只能通過(guò)注解的方式定義
第三步:使用:
1、查詢結(jié)果集字段定義
<resultMap id="UserResult" type="User"> <id column="id" property="id"/> <result column="interests" property="interests" javaType="[Ljava.lang.String;" jdbcType="VARCHAR"/> </resultMap>
或者
<resultMap id="UserResult" type="User"> <id column="id" property="id"/> <result column="interests" property="interests" typeHandler="com.tiantian.mybatis.handler.StringArrayTypeHandler" /> </resultMap>
即如果直接指明了typehandler類(lèi)可以不用寫(xiě)javatype和jdbctype,即使寫(xiě)了mybatis也不用
2、傳參數(shù)查詢或者修改
<if test="txLogStatus != null">
txLogStatus = #{txLogStatus, typeHandler=com.rrcp.util.typehandlers.EventStatusTypeHandler},
</if>
同理此處的typehandler也可以換成jdbcType和javaType
總結(jié):
注冊(cè)的時(shí)候和使用的時(shí)候盡量保持一致或者都寫(xiě)完整,如果不統(tǒng)一,會(huì)找不到相應(yīng)的typehandler從而報(bào)錯(cuò),我們的目的是要正確使用typehandler的處理機(jī)制,并不想深究mybatis在注冊(cè)和查找使用的算法,所以只要成功即可。有時(shí)間閑的蛋疼的哥們可以研究下,少注冊(cè)一個(gè)屬性,會(huì)產(chǎn)生什么后果,不過(guò)如果你研究透了,說(shuō)不定myabtis的下個(gè)版本就改了。
以上所述是小編給大家介紹的Mybatis實(shí)現(xiàn)自定義的typehandler三步曲,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- MyBatis自定義typeHandler的完整實(shí)例
- MyBatis-Plus如何通過(guò)注解使用TypeHandler
- Mybatis實(shí)現(xiàn)自定義類(lèi)型轉(zhuǎn)換器TypeHandler的方法
- Mybatis中自定義TypeHandler處理枚舉詳解
- Mybatis自定義TypeHandler解決特殊類(lèi)型轉(zhuǎn)換問(wèn)題詳解
- Mybatis實(shí)戰(zhàn)之TypeHandler高級(jí)進(jìn)階
- Mybatis之類(lèi)型處理器TypeHandler的作用與自定義方式
- MyBatis使用自定義TypeHandler轉(zhuǎn)換類(lèi)型的實(shí)現(xiàn)方法
- MyBatis-Plus?中?typeHandler?的使用實(shí)例詳解
- MyBatis中TypeHandler的使用教程詳解
- 一文搞懂MyBatis中TypeHandler機(jī)制
相關(guān)文章
Java數(shù)組模擬優(yōu)先級(jí)隊(duì)列數(shù)據(jù)結(jié)構(gòu)的實(shí)例
這篇文章主要介紹了Java數(shù)組模擬優(yōu)先級(jí)隊(duì)列數(shù)據(jù)結(jié)構(gòu)的實(shí)例,優(yōu)先級(jí)隊(duì)列中的元素會(huì)被設(shè)置優(yōu)先權(quán),本文的例子借助了Java中的TreeSet和TreeMap,需要的朋友可以參考下2016-04-04
SpringBoot全局配置long轉(zhuǎn)String丟失精度的問(wèn)題解決
web項(xiàng)目中,Java后端傳過(guò)來(lái)的Long/long類(lèi)型,前端JS接收會(huì)丟失精度。那么應(yīng)該如何解決,本文就來(lái)介紹一下幾種方法,感興趣的可以了解一下2021-08-08
Idea2020.2創(chuàng)建JavaWeb項(xiàng)目(部署Tomcat)方法詳解
這篇文章主要介紹了Idea2020.2創(chuàng)建JavaWeb項(xiàng)目(部署Tomcat)方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08
java定時(shí)任務(wù)的實(shí)現(xiàn)方法
java定時(shí)任務(wù)的實(shí)現(xiàn)方法,需要的朋友可以參考一下2013-03-03
java動(dòng)態(tài)修改nacos的yml配置方式
文章介紹修改Nacos配置文件的兩種方式:snakeyaml忽略注釋但修改直接,eo-yaml保留注釋但格式變化,建議配置項(xiàng)多時(shí)用數(shù)據(jù)庫(kù)存儲(chǔ),強(qiáng)調(diào)實(shí)際應(yīng)用需充分評(píng)估和測(cè)試以確保可靠性2025-08-08
通過(guò)代碼實(shí)例深入解析Java重寫(xiě)和重載
這篇文章主要介紹了通過(guò)代碼實(shí)例深入解析Java重寫(xiě)和重載,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11
IDEA使用JDBC導(dǎo)入配置jar包連接MySQL數(shù)據(jù)庫(kù)
這篇文章介紹了IDEA使用JDBC安裝配置jar包連接MySQL數(shù)據(jù)庫(kù)的方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-12-12
Java獲取當(dāng)前時(shí)間并轉(zhuǎn)化為yyyy-MM-dd?HH:mm:ss格式的多種方式
這篇文章主要介紹了Java獲取當(dāng)前時(shí)間并轉(zhuǎn)化為yyyy-MM-dd?HH:mm:ss格式的多種方式,每種方式結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2024-03-03

