2017-01-05 4 views
2

У меня есть булевы, вставленные в мою базу данных как Y/N. Когда я пытаюсь сопоставить результат с логическим типом java, он всегда устанавливает значение false в любом случае в моем pojo.MyBatis: Map String to boolean

Есть ли способ сопоставить String с булевым? Вот мой код:

<resultMap id="getFlag" type="MyPojo"> 
    <result property="myFlag" column="MY_FLAG"/> 
</resultMap> 
+0

Возможный дубликат [Настроить спящий режим (с помощью JPA) для хранения Y/N для типа Boolean вместо 0/1] (http://stackoverflow.com/questions/1154833/configure-hibernate-using-jpa-to-store-yn-for-type-boolean-instead -of-0-1) – DimaSan

+0

Вы можете преобразовать 'Y/N' в' boolean' в вашем запросе sql. – Blank

ответ

3

Что вам нужно, это typeHandler для вас Y/N Boolean: (more explained here) Actual Handler:

public class YesNoBooleanTypeHandler extends BaseTypeHandler<Boolean> { 

    @Override 
    public void setNonNullParameter(PreparedStatement ps, int i, Boolean parameter, JdbcType jdbcType) 
      throws SQLException { 
     ps.setString(i, convert(parameter)); 
    } 

    @Override 
    public Boolean getNullableResult(ResultSet rs, String columnName) 
      throws SQLException { 
     return convert(rs.getString(columnName)); 
    } 

    @Override 
    public Boolean getNullableResult(ResultSet rs, int columnIndex) 
      throws SQLException { 
     return convert(rs.getString(columnIndex)); 
    } 

    @Override 
    public Boolean getNullableResult(CallableStatement cs, int columnIndex) 
      throws SQLException { 
     return convert(cs.getString(columnIndex)); 
    } 

    private String convert(Boolean b) { 
     return b ? "Y" : "N"; 
    } 

    private Boolean convert(String s) { 
     return s.equals("Y"); 
    } 

} 

Ваше использование:

<result property="myFlag" column="MY_FLAG" javaType="java.lang.Boolean" jdbcType="VARCHAR" typeHandler="com.foo.bar.YesNoBooleanTypeHandler" />