【Mybatis】mybatis xml 对int类型如何写if条件避免java的默认值0的干扰

mybatis xml 对int类型如何写if条件避免java的默认值0的干扰

在 MyBatis 中,如果你想在 XML 配置中使用 <if> 标签来判断 int 类型的参数,并且避免 Java 的默认值 0 干扰你的判断,你可以使用 Integer 包装类而不是基本类型 int。这是因为 Integer 可以为 null,而基本类型 int 不能。

示例表结构

假设有一个名为 work_orders 的表:

sql 复制代码
CREATE TABLE work_orders (
    id INT AUTO_INCREMENT PRIMARY KEY,
    order_status INT,
    order_time DATETIME
);

使用 Integer 类型参数

1. Mapper 接口

首先,在你的 Mapper 接口中使用 Integer 类型:

java 复制代码
package com.example.mapper;

import com.example.model.WorkOrder;
import org.apache.ibatis.annotations.Param;
import java.util.List;

public interface WorkOrderMapper {

    List<WorkOrder> selectWorkOrders(@Param("orderStatus") Integer orderStatus);
}
2. Mapper XML 文件

在 XML 文件中,你可以使用 <if> 标签来判断 orderStatus 是否为 null,以避免默认值 0 的干扰:

xml 复制代码
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.mapper.WorkOrderMapper">

    <!-- 动态查询示例 -->
    <select id="selectWorkOrders" resultType="com.example.model.WorkOrder">
        SELECT * FROM work_orders
        WHERE 1=1
        <if test="orderStatus != null">
            AND order_status = #{orderStatus}
        </if>
    </select>

</mapper>

示例查询

假设你希望查询 order_status1 的所有工单,你可以像这样调用:

java 复制代码
package com.example;

import com.example.mapper.WorkOrderMapper;
import com.example.model.WorkOrder;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;

import java.util.List;

@Service
public class WorkOrderService {

    @Autowired
    private WorkOrderMapper workOrderMapper;

    public List<WorkOrder> getWorkOrders(Integer orderStatus) {
        return workOrderMapper.selectWorkOrders(orderStatus);
    }
}

在你的业务代码中调用 getWorkOrders(1) 将会返回所有 order_status1 的工单。

注意事项

  1. 使用包装类 :确保在 Mapper 接口中使用 Integer 类型,而不是基本类型 int
  2. 避免默认值干扰 :通过使用 <if> 标签和 null 判断,可以避免默认值 0 对查询条件的干扰。
  3. SQL 安全性:确保你传递的参数是安全的,避免 SQL 注入等安全问题。

完整示例

以下是完整的 Mapper 接口和 XML 文件示例:

WorkOrderMapper.java
java 复制代码
package com.example.mapper;

import com.example.model.WorkOrder;
import org.apache.ibatis.annotations.Param;
import java.util.List;

public interface WorkOrderMapper {

    List<WorkOrder> selectWorkOrders(@Param("orderStatus") Integer orderStatus);
}
WorkOrderMapper.xml
xml 复制代码
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.mapper.WorkOrderMapper">

    <!-- 动态查询示例 -->
    <select id="selectWorkOrders" resultType="com.example.model.WorkOrder">
        SELECT * FROM work_orders
        WHERE 1=1
        <if test="orderStatus != null">
            AND order_status = #{orderStatus}
        </if>
    </select>

</mapper>

通过这种方式,你可以确保在进行条件判断时不会受到 Java 默认值 0 的干扰。

相关推荐
qq_12498707533 分钟前
基于JavaWeb的大学生房屋租赁系统(源码+论文+部署+安装)
java·数据库·人工智能·spring boot·计算机视觉·毕业设计·计算机毕业设计
短剑重铸之日9 分钟前
《设计模式》第十一篇:总结
java·后端·设计模式·总结
若鱼191932 分钟前
SpringBoot4.0新特性-Observability让生产环境更易于观测
java·spring
觉醒大王40 分钟前
强女思维:着急,是贪欲外显的相。
java·论文阅读·笔记·深度学习·学习·自然语言处理·学习方法
努力学编程呀(๑•ี_เ•ี๑)1 小时前
【在 IntelliJ IDEA 中切换项目 JDK 版本】
java·开发语言·intellij-idea
码农小卡拉1 小时前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot
向上的车轮1 小时前
为什么.NET(C#)转 Java 开发时常常在“吐槽”Java:checked exception
java·c#·.net
Dragon Wu1 小时前
Spring Security Oauth2.1 授权码模式实现前后端分离的方案
java·spring boot·后端·spring cloud·springboot·springcloud
跳动的梦想家h1 小时前
环境配置 + AI 提效双管齐下
java·vue.js·spring
坚持就完事了1 小时前
Java中的集合
java·开发语言