用mybatis-plus写一个分页查询加条件查询
时间: 2024-06-06 20:02:05 浏览: 14
假设要查询用户表中年龄大于等于18岁的用户信息,按照注册时间降序排列,每页显示10条数据,查询第2页的数据。
1. 创建实体类
首先创建一个User实体类,包含以下字段:
```java
public class User {
private Long id;
private String name;
private Integer age;
private String email;
private Date createTime;
private Date updateTime;
}
```
2. 创建Mapper接口
创建一个UserMapper接口,继承BaseMapper接口,用于操作用户表。
```java
public interface UserMapper extends BaseMapper<User> {
}
```
3. 编写Mapper.xml文件
在resources目录下创建mapper文件夹,并在其中创建UserMapper.xml文件,用于编写SQL语句。
```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.UserMapper">
<select id="selectUserByAgeAndPage" resultType="User">
select * from user
where age >= #{age}
order by create_time desc
</select>
</mapper>
```
4. 编写Service层
创建一个UserService接口和实现类UserServiceImpl,用于调用Mapper接口中的方法。
```java
public interface UserService {
Page<User> selectUserByAgeAndPage(int age, int pageNum, int pageSize);
}
@Service
public class UserServiceImpl implements UserService {
@Autowired
private UserMapper userMapper;
@Override
public Page<User> selectUserByAgeAndPage(int age, int pageNum, int pageSize) {
Page<User> page = new Page<>(pageNum, pageSize);
LambdaQueryWrapper<User> queryWrapper = Wrappers.lambdaQuery();
queryWrapper.ge(User::getAge, age);
queryWrapper.orderByDesc(User::getCreateTime);
return userMapper.selectPage(page, queryWrapper);
}
}
```
5. 测试查询
在测试类中调用UserService的selectUserByAgeAndPage方法,查询年龄大于等于18岁的用户信息,按照注册时间降序排列,每页显示10条数据,查询第2页的数据。
```java
@SpringBootTest
class MybatisPlusApplicationTests {
@Autowired
private UserService userService;
@Test
void testSelectUserByAgeAndPage() {
Page<User> page = userService.selectUserByAgeAndPage(18, 2, 10);
System.out.println("总记录数:" + page.getTotal());
System.out.println("当前页数:" + page.getCurrent());
System.out.println("每页显示条数:" + page.getSize());
System.out.println("总页数:" + page.getPages());
System.out.println("是否有下一页:" + page.hasNext());
System.out.println("是否有上一页:" + page.hasPrevious());
System.out.println("查询结果:" + page.getRecords());
}
}
```
运行测试类,查看查询结果。
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![docx](https://img-home.csdnimg.cn/images/20210720083331.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)