Как использовать List
перечислений в качестве параметра для запроса MyBatis?Я уже создал обработчик типа для него и указал сопоставленный тип, как описано в этом другом вопросе .Он возвращает счет 0, когда он должен быть тысяч.
@Mapper
public interface BadgeMapper {
@Select("select count(*) from badges where appType in (#{appTypes})")
int countByType(@Param("appTypes") List<AppType> appTypes);
package com.example.mapper;
@MappedTypes({AppType.class})
public class AppTypeTypeHandler implements TypeHandler<AppType> {
@Override
public void setParameter(PreparedStatement ps, int i, AppType parameter, JdbcType jdbcType) throws SQLException {
ps.setString(i, parameter.toString()); // use toString not name()
}
public static enum AppType {
ANDROID("A", "Android"), THEME("T", "Theme"), ...
private String val;
private String desc;
AppType(String v, String d) { val = v; desc = d; }
public String toString() {
return val;
}
application.properties
mybatis.type-handlers-package=com.example.mapper
Журналы отладки отображаются с правильными значениями ('A',' T ',' ST '), но для подсчета выводится 0.
System.out.println(badgeMapper.countByType(appTypes));
Console
c.s.s.mapper.BadgeMapper.countByType : ==> Preparing: select count(*) from badges where appType in (?)
c.s.s.mapper.BadgeMapper.countByType : ==> Parameters: [A, T, ST](ArrayList)
0
MySQL
mysql> select count(*) from badges where appType in ('A', 'T', 'ST');
+----------+
| count(*) |
+----------+
| 2365 |
Справочная документация для MyBatis XML: http://www.mybatis.org/mybatis-3/configuration.html#typeHandlers