本文主要是介绍Mybatis配置-处理枚举类型(Handling Enums),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
如果您想要映射一个枚举类型,您需要使用EnumTypeHandler或EnumOrdinalTypeHandler中的其中一个。
例如,假设我们需要存储用于对某些数字进行四舍五入的舍入模式。默认情况下,MyBatis使用EnumTypeHandler将枚举值转换为它们的名称。
请注意,EnumTypeHandler在某种意义上是特殊的,与其他处理程序不同,它不仅处理一个特定的类,而是处理任何继承自Enum的类。
然而,我们可能不想存储枚举的名称。我们的数据库管理员可能坚持要使用整数代码。这同样简单:在配置文件的typeHandlers中添加EnumOrdinalTypeHandler,现在每个RoundingMode将使用其序号值映射到一个整数。
<!-- mybatis-config.xml -->
<typeHandlers><typeHandler handler="org.apache.ibatis.type.EnumOrdinalTypeHandler"javaType="java.math.RoundingMode"/>
</typeHandlers>
如果您想在一个地方将相同的枚举映射到字符串形式,在另一个地方映射为整数形式怎么办?
自动映射器将自动使用EnumOrdinalTypeHandler,所以如果我们希望回到使用普通的EnumTypeHandler,我们必须显式设置这些SQL语句要使用的类型处理程序。
<!DOCTYPE mapperPUBLIC "-//mybatis.org//DTD Mapper 3.0//EN""https://mybatis.org/dtd/mybatis-3-mapper.dtd"><mapper namespace="org.apache.ibatis.submitted.rounding.Mapper"><resultMap type="org.apache.ibatis.submitted.rounding.User" id="usermap"><id column="id" property="id"/><result column="name" property="name"/><result column="funkyNumber" property="funkyNumber"/><result column="roundingMode" property="roundingMode"/></resultMap><select id="getUser" resultMap="usermap">select * from users</select><insert id="insert">insert into users (id, name, funkyNumber, roundingMode) values (#{id}, #{name}, #{funkyNumber}, #{roundingMode})</insert><resultMap type="org.apache.ibatis.submitted.rounding.User" id="usermap2"><id column="id" property="id"/><result column="name" property="name"/><result column="funkyNumber" property="funkyNumber"/><result column="roundingMode" property="roundingMode"typeHandler="org.apache.ibatis.type.EnumTypeHandler"/></resultMap><select id="getUser2" resultMap="usermap2">select * from users2</select><insert id="insert2">insert into users2 (id, name, funkyNumber, roundingMode) values (#{id}, #{name}, #{funkyNumber}, #{roundingMode, typeHandler=org.apache.ibatis.type.EnumTypeHandler})</insert></mapper>
请注意,这将强制我们在select语句中使用resultMap而不是resultType。
这篇关于Mybatis配置-处理枚举类型(Handling Enums)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!