java - MyBatis Java boolean 值到 Sql 枚举

标签 java mybatis

我在我的项目中使用 MyBatis 和 MySql。

我有:

myField ENUM('是','否')

我想映射到 java boolean 值:

我知道我可以修改所有mybatis模板,例如:

<update id="update">
UPDATE
myTable
   <set>
        ...
       <if test="myField != null">myField = <choose>
           <when test="myField == true">'yes'</when>
           <otherwise>'no'</otherwise>
           </choose>,
        </if>
        ...
    </set>
 WHERE
    ...
 </update>

但是我可以用更方便的方式做到这一点吗?

最佳答案

似乎解决这个问题的最好方法是实现我自己的 boolean 类型处理程序:

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 ? "yes" : "no";
    }

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

}

然后在映射器模板中使用它:

<update id="update">
UPDATE
myTable
   <set>
        ...
       <if test="myField != null">myField = #{myField ,typeHandler=YesNoBooleanTypeHandler}</if>
        ...
    </set>
 WHERE
    ...
 </update>

关于java - MyBatis Java boolean 值到 Sql 枚举,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13474296/

相关文章:

java - 无法在我的另一台电脑上运行相同的 servlet/hibernate 项目

java - Google 云端硬盘 session 到期

java - ($Proxy6) org.postgresql.jdbc4.Jdbc4Connection@5894585b,这是什么意思?

java - MyBatis Spring MVC 错误 : Invalid bound statement (not found)

java - MyBatis SqlSession 接口(interface)的 insert()、delete()、select() 和 update() 返回什么?

java - Web 应用程序中的 Quartz 调度程序

java - 当我们使用类实例调用静态方法/函数时会发生什么?

java - Android Sqlite 操作

java - Mybatis分组查询超时

Java - MyBatis - 一次处理一条记录