Mybatis Enum处理

2019-05-10  本文已影响0人  蜡笔没了小新_e8c0

通过Enum往数据库中添加数据默认在数据库中保存的是Enum的name。如果要保存Enum的value,可以通过改变handler来实现。

    <typeHandlers>
        <typeHandler handler="org.apache.ibatis.type.EnumOrdinalTypeHandler" javaType="com.StatusEnum"></typeHandler>
    </typeHandlers>

自定义Hanlder

接口:

public enum StatusEnum {

    SUCCESS(200,"成功"),FAIL(404,"失败");

    private int code;
    private String msg;

     StatusEnum(){}

     StatusEnum(int code, String msg) {
        this.code = code;
        this.msg = msg;
    }

    public int getCode() {
        return code;
    }

    public void setCode(int code) {
        this.code = code;
    }

    public String getMsg() {
        return msg;
    }

    public void setMsg(String msg) {
        this.msg = msg;
    }

    public static StatusEnum getStatus(int code){
         switch (code){
             case 200 : return SUCCESS;
             default: return FAIL;
         }
    }
}

TypeHandler实现:

/**
* 枚举类型解析器
*/
public class MyEnumHandler implements TypeHandler<StatusEnum> {
   @Override
   public void setParameter(PreparedStatement preparedStatement, int i, StatusEnum statusEnum, JdbcType jdbcType) throws SQLException {
       preparedStatement.setString(i,Integer.toString(statusEnum.getCode()));
   }

   @Override
   public StatusEnum getResult(ResultSet resultSet, String s) throws SQLException {

       String code = resultSet.getString(s);

       return StatusEnum.getStatus(Integer.parseInt(code));
   }

   @Override
   public StatusEnum getResult(ResultSet resultSet, int i) throws SQLException {

       String code = resultSet.getString(i);

       return StatusEnum.getStatus(Integer.parseInt(code));
   }

   @Override
   public StatusEnum getResult(CallableStatement callableStatement, int i) throws SQLException {

       String code = callableStatement.getString(i);

       return StatusEnum.getStatus(Integer.parseInt(code));
   }
}

配置属性

    <typeHandlers>
        <!--<typeHandler handler="org.apache.ibatis.type.EnumOrdinalTypeHandler" javaType="com.StatusEnum"></typeHandler>-->
        <typeHandler handler="com.myHandler.MyEnumHandler" javaType="com.StatusEnum"/>
    </typeHandlers>

我们也可以直接在SQL语句中指定:
#{statusEnum,typeHandler=com.myHandler.MyEnumHandler}

上一篇 下一篇

猜你喜欢

热点阅读