mybatis中xml文件中对int类型参数的校验

问题:springcould项目中有一个多条件查询的场景,其中有一个条件项是下拉框,其中的type值类型是int,分别是0和1。写完测试发现其他查询条件都好用,唯独当type值为0的时候这个条件直接被代码无视了。

<where>
      <if test="legalCode != null and legalCode != ''">
        and tils.legal_code= #{legalCode,jdbcType=VARCHAR}
      </if>
      <if test="companyName != null and companyName != ''">
        and tils.company_name like concat('%',#{companyName,jdbcType=VARCHAR},'%')
      </if>
      <if test="isFranchisees != null and isFranchisees !=''">
        and tils.is_franchisees= #{isFranchisees,jdbcType=TINYINT}
      </if>
      <if test="applicationStatus != null and applicationStatus != ''">
        and tsma.application_status= #{applicationStatus,jdbcType=VARCHAR}
      </if>
    </where>

原因:因为当isFranchisees 的值为0的时候,它的数据类型为Integer,Mybatis是认为0为' ' 的,所以这个判断是为false,所以下面这个下面这个查询查询条件会直接被过滤掉。

解决:所以直接把 isFranchisees !='' 这个条件删掉就可以

<if test="isFranchisees != null">
        and tils.is_franchisees= #{isFranchisees,jdbcType=TINYINT}
      </if>

下面的没有用啊!

下面的没有用啊!

下面的没有用啊!

下面的没有用啊!
写够500字,否则
文章质量提示
文章质量提示
此文章质量较低,不会获得较多流量扶持! 可能的原因为:篇幅太短,广告涉嫌违规,外链过多,缺少代码,图片涉嫌违规
文章质量提示
此文章质量较低,不会获得较多流量扶持! 可能的原因为:篇幅太短,广告涉嫌违规,外链过多,缺少代码,图片涉嫌违规
此文章质量较低,不会获得较多流量扶持! 可能的原因为:篇幅太短,广告涉嫌违规,外链过多,缺少代码,图片涉嫌违规

此文章质量较低,不会获得较多流量扶持! 可能的原因为:篇幅太短,广告涉嫌违规,外链过多,缺少代码,图片涉嫌违规
文章质量提示
此文章质量较低,不会获得较多流量扶持! 可能的原因为:篇幅太短,广告涉嫌违规,外链过多,缺少代码,图片涉嫌违规
此文章质量较低,不会获得较多流量扶持! 可能的原因为:篇幅太短,广告涉嫌违规,外链过多,缺少代码,图片涉嫌违规

此文章质量较低,不会获得较多流量扶持! 可能的原因为:篇幅太短,广告涉嫌违规,外链过多,缺少代码,图片涉嫌违规
文章质量提示
此文章质量较低,不会获得较多流量扶持! 可能的原因为:篇幅太短,广告涉嫌违规,外链过多,缺少代码,图片涉嫌违规
此文章质量较低,不会获得较多流量扶持! 可能的原因为:篇幅太短,广告涉嫌违规,外链过多,缺少代码,图片涉嫌违规


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis ,可以通过自定义 TypeHandler 实现将 PostgreSQL 的 int8 类型转换为实体类的 String 类型。 TypeHandler 是 MyBatis 一个非常重要的组件,它用于将 Java 类型和 JDBC 类型之间进行转换。在 MyBatis ,默认的 TypeHandler 可以将大部分常见的 Java 类型与 JDBC 类型之间进行转换。但是对于一些特殊的类型,如 PostgreSQL 的 int8 类型,可能需要自定义 TypeHandler。 以下是实现将 PostgreSQL 的 int8 类型转换为实体类的 String 类型的示例代码: 1. 首先定义一个继承自 BaseTypeHandler<String> 的 TypeHandler 类,例如: ``` public class Int8ToStringTypeHandler extends BaseTypeHandler<String> { @Override public void setNonNullParameter(PreparedStatement ps, int i, String parameter, JdbcType jdbcType) throws SQLException { ps.setLong(i, Long.parseLong(parameter)); } @Override public String getNullableResult(ResultSet rs, String columnName) throws SQLException { long result = rs.getLong(columnName); return result == 0 && rs.wasNull() ? null : String.valueOf(result); } @Override public String getNullableResult(ResultSet rs, int columnIndex) throws SQLException { long result = rs.getLong(columnIndex); return result == 0 && rs.wasNull() ? null : String.valueOf(result); } @Override public String getNullableResult(CallableStatement cs, int columnIndex) throws SQLException { long result = cs.getLong(columnIndex); return result == 0 && cs.wasNull() ? null : String.valueOf(result); } } ``` 2. 在 MyBatis 的配置文件,配置该 TypeHandler: ``` <typeHandlers> <typeHandler javaType="java.lang.String" jdbcType="BIGINT" handler="com.example.Int8ToStringTypeHandler"/> </typeHandlers> ``` 3. 在需要使用该 TypeHandler 的地方,将对应的 Java 类型设置为 String 类型即可。 ``` @Select("SELECT id, name, CAST(int8_column AS TEXT) AS int8String FROM my_table") @Results({ @Result(property = "id", column = "id"), @Result(property = "name", column = "name"), @Result(property = "int8String", column = "int8String") }) List<MyEntity> selectMyEntities(); ``` 以上示例代码,我们在查询 SQL 使用了 CAST 函数将 int8 类型转换为文本类型,并且在 MyBatis int8String 属性的 Java 类型设置为 String 类型MyBatis 会自动使用我们定义的 TypeHandler 将查询结果转换为 String 类型
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值