mybatis判断Long,Integer类型的条件是否为空

在使用spring和mybatis时,如果对象的某个属性是整数类型,最好定义其为Long,Integer包装类型,不要使用long,int。因为long,int不传值时,默认为0,这样作为过滤条件会导致查询结果有误。

一般我们在mybatis中判断条件是否为空时写法如下:

<if test="pinyinCode != null and pinyinCode != ''">
    AND bs.PINYIN_CODE = #{pinyinCode, jdbcType=VARCHAR }
</if>

如果是Long,Integer类型时,如果设置其为0,那么在mybatis中 !=‘’ 是不成立的,因此对于Long,Integer类型做如下判断:
 

 <if test="anesthetist != null">
      AND bs.ANESTHETIST = #{anesthetist, jdbcType=INTEGER }
 </if>

 

  • 7
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
JacksonTypeHandler是MyBatis框架用于处理Java类型与数据库类型之间转换的类型处理器,它使用了Jackson库来进行Java对象与JSON字符串之间的转换。如果你发现JacksonTypeHandler把Long类型解析为了Integer,有可能是因为你在MyBatis映射文件使用了错误的Java类型。 首先,请检查你的数据库表结构是否正确,确保对应的列类型Long类型。 然后,请检查你的MyBatis映射文件是否正确定义了Java类型。例如,如果你的列名为"age",并且对应的Java属性为age,那么你需要在映射文件将其定义为Long类型: ``` <resultMap id="userResultMap" type="User"> <result column="age" property="age" jdbcType="BIGINT" javaType="java.lang.Long" /> </resultMap> ``` 如果你使用了注解方式进行映射,那么你需要在对应的Java属性上标注@JsonSerialize和@JsonDeserialize注解,指定对应的序列化和反序列化类,例如: ``` @JsonSerialize(using = ToStringSerializer.class) @JsonDeserialize(using = LongDeserializer.class) private Long age; ``` 最后,如果你使用了自定义的Jackson配置,那么请确保你正确地配置了Long类型的序列化和反序列化。你可以使用以下代码来配置Long类型的序列化和反序列化: ``` ObjectMapper mapper = new ObjectMapper(); SimpleModule module = new SimpleModule(); module.addSerializer(Long.class, ToStringSerializer.instance); module.addDeserializer(Long.class, LongDeserializer.instance); mapper.registerModule(module); ``` 总之,如果你发现JacksonTypeHandler把Long类型解析为了Integer,请检查你的Java类型定义以及Jackson配置是否正确。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值