首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在MyBatis中,有没有办法在foreach中使用枚举序号

在MyBatis中,有没有办法在foreach中使用枚举序号
EN

Stack Overflow用户
提问于 2019-10-15 20:25:03
回答 1查看 351关注 0票数 0

我试图在foreach循环中动态地过滤带有mybatis的select查询。

下面是我的xml映射器中的一个示例:

代码语言:javascript
复制
<if test="array!= null and array.length > 0">
   AND arrayValCol IN
      <foreach item="item" collection="array" separator="','" open="('" close="')">
         ${item}
      </foreach>
</if>

但是数组包含枚举作为值,我在mybatis文档或google中找不到任何解决方案。

有没有办法解决这个问题呢?

EN

回答 1

Stack Overflow用户

发布于 2019-10-15 21:04:36

  • 默认情况下,MyBatis使用EnumTypeHandler,它在绑定枚举参数时调用name()方法。你需要告诉MyBatis改用EnumOrdinalTypeHandler
  • 只要有可能,你就应该用#{}代替${}。请参阅FAQ.

代码语言:javascript
复制
<if test="array!= null and array.length > 0">
  AND arrayValCol IN
  <foreach item="item" collection="array" separator="," open="(" close=")">
    #{item,typeHandler=org.apache.ibatis.type.EnumOrdinalTypeHandler}
  </foreach>
</if>

还可以通过在配置中指定defaultEnumTypeHandler来更改默认枚举类型处理程序。

代码语言:javascript
复制
<settings>
  <setting name="defaultEnumTypeHandler"
    value="org.apache.ibatis.type.EnumOrdinalTypeHandler"/>
</settings>
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58394646

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档