欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis實(shí)現(xiàn)自定義的typehandler三步曲

 更新時(shí)間:2016年07月22日 10:29:18   作者:liuzhiyong0524  
這篇文章主要介紹了Mybatis實(shí)現(xiàn)自定義的typehandler三步曲的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下

第一步實(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)站的支持!

相關(guān)文章

最新評(píng)論