2017-01-05 4 views
2

나는 부울을 데이터베이스에 Y/N로 삽입했습니다. 부울 Java 형식에 결과를 매핑하려고하면 항상 내 pojo의 모든 경우에 false로 설정됩니다.MyBatis : 문자열을 부울로 매핑

문자열을 부울로 매핑 할 수있는 방법이 있습니까? 이 사용자 지정 TypeHandler를 구현 보는 것 할

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

가능한 중복 (사용 JPA) Y/N을 0/1 대신 Boolean 유형으로 저장] (http://stackoverflow.com/questions/1154833/configure-hibernate-using-jpa-to-store-yn-for-type-boolean-instead -of-0-1) – DimaSan

+0

질의 sql에서'Y/N'을'boolean'으로 변환 할 수 있습니다. – Blank

답변

3

는 당신이 필요로하는 것은 당신 Y에 대한 typeHandler입니다/N 부울 유형 : (more explained here) 실제 처리기 :

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" />