Mybatis bool 类型匹配

将sql查询到的bool类型,与java bean中的Boolean类型进行匹配。

mybatis

<result property="amountDisplayed" jdbcType="VARCHAR" column="AMOUNT_DISPLAYED"/>
SELECT CASE WHEN D.SUM_AMOUNT_FIELD_ID IS NULL AND D.SUM_AMOUNT_AREA_ID IS NULL THEN 'FALSE' ELSE 'TRUE' END AS AMOUNT_DISPLAYED
FROM T_BILL_DEFINE D

javaBean

private Boolean amountDisplayed;

原因:Boolean可以通过String作为参数进行构造
在这里插入图片描述
在这里插入图片描述

总结:可以通过varchar-boolean实现类型的匹配

以上都是胡说八道,需要实现Boolean typeHandler类型转换器的

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis并没有原生的bool类型,而是使用了基本的Java类型MyBatis的自定义类型来代表布尔值。在MyBatis中,我们可以通过以下两种方式来表示bool类型: 1.使用Java的布尔类型来表示: MyBatis支持将Java的布尔类型Boolean)作为参数传递给SQL,也可以将SQL的查询结果映射到Java的布尔类型中。在数据库中,布尔类型通常以整数或字符串形式存储,因此需要将它们转换成Java的布尔类型。 例如,我们可以在Mapper映射文件中定义如下参数: ```xml <select id="findUserByIsValid" resultType="User"> SELECT * FROM USER WHERE IS_VALID=#{isValid} </select> ``` 可以看到,其中isValid参数使用了Boolean类型,因为我们希望查询出isValid=true的用户。在代码中调用Mapper时,我们需要传递一个布尔值作为参数: ```java boolean isValid = true; User user = userMapper.findUserByIsValid(isValid); ``` 2.使用自定义类型来表示: MyBatis也支持使用自定义类型来表示布尔值。这在一些特殊场景下很有用,比如当我们希望将数据库中的数值类型映射成布尔类型时。 在MyBatis中,自定义类型是通过实现TypeHandler接口来完成的。例如,我们可以自定义一个BoolTypeHandler类来将数据库中的0和1转换成Java的布尔类型: ```java public class BoolTypeHandler implements TypeHandler<Boolean> { @Override public void setParameter(PreparedStatement ps, int i, Boolean parameter, JdbcType jdbcType) throws SQLException { ps.setInt(i, parameter ? 1 : 0); } @Override public Boolean getResult(ResultSet rs, String columnName) throws SQLException { int value = rs.getInt(columnName); return value == 1; } @Override public Boolean getResult(ResultSet rs, int columnIndex) throws SQLException { int value = rs.getInt(columnIndex); return value == 1; } @Override public Boolean getResult(CallableStatement cs, int columnIndex) throws SQLException { int value = cs.getInt(columnIndex); return value == 1; } } ``` 当我们需要将数据库中的一个字段映射成布尔类型时,可以在Mapper映射文件中使用自定义类型: ```xml <resultMap id="userResultMap" type="User"> <result column="IS_VALID" property="valid" typeHandler="com.example.BoolTypeHandler"/> </resultMap> ``` 通过使用自定义类型,我们可以更加灵活地处理布尔类型的数据,并且避免了在Java和数据库之间频繁转换的问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值