温馨提示×

MyBatis条件查询与分页结合的方法

小樊
85
2024-08-20 03:48:37
栏目: 编程语言

MyBatis是一个优秀的持久层框架,可以通过XML配置文件或者注解方式进行SQL语句的编写和执行。在MyBatis中,条件查询和分页查询是经常使用的功能,结合起来可以更灵活地进行数据查询。

下面是一个示例代码,演示了如何在MyBatis中进行条件查询和分页查询:

  1. 在Mapper接口中定义查询方法:
public interface UserMapper {
    
    List<User> findUsersByCondition(@Param("username") String username, @Param("age") Integer age, RowBounds rowBounds);
    
}
  1. 在Mapper XML文件中编写查询SQL语句:
<select id="findUsersByCondition" parameterType="java.util.Map" resultType="User">
    SELECT * FROM user
    <where>
        <if test="username != null">
            AND username = #{username}
        </if>
        <if test="age != null">
            AND age = #{age}
        </if>
    </where>
</select>
  1. 在Service层中调用Mapper接口的方法:
@Autowired
private UserMapper userMapper;

public List<User> findUsersByCondition(String username, Integer age, int offset, int limit) {
    RowBounds rowBounds = new RowBounds(offset, limit);
    return userMapper.findUsersByCondition(username, age, rowBounds);
}
  1. 在Controller层中处理请求并返回结果:
@RequestMapping("/users")
public List<User> getUsers(@RequestParam(required = false) String username,
                           @RequestParam(required = false) Integer age,
                           @RequestParam(defaultValue = "0") int page,
                           @RequestParam(defaultValue = "10") int size) {
    int offset = page * size;
    return userService.findUsersByCondition(username, age, offset, size);
}

通过以上步骤,我们可以实现在MyBatis中进行条件查询与分页查询的功能。在Mapper XML文件中使用<where>标签可以动态拼接查询条件,在Service层使用RowBounds对象实现分页查询,在Controller层处理请求参数并调用Service层方法获取数据。这样可以更加灵活地进行数据查询操作。

0