springboot+mybatis分页查询
时间: 2023-08-30 13:09:50 浏览: 143
在Spring Boot项目中使用MyBatis进行分页查询,你可以按照以下步骤进行操作:
1. 首先,确保你的Spring Boot项目中已经引入了MyBatis的相关依赖。可以在你的pom.xml文件中添加以下依赖:
```xml
<dependency>
<groupId>org.mybatis.spring.boot</groupId>
<artifactId>mybatis-spring-boot-starter</artifactId>
<version>latest_version</version>
</dependency>
```
2. 创建一个Mapper接口,用于定义分页查询的方法。例如:
```java
import org.apache.ibatis.annotations.Mapper;
import java.util.List;
@Mapper
public interface UserMapper {
List<User> getUsersByPage(int offset, int limit);
}
```
3. 在对应的Mapper XML文件中编写SQL语句,使用数据库的分页功能。例如,使用MySQL的LIMIT语句来实现分页查询:
```xml
<select id="getUsersByPage" resultType="User">
SELECT * FROM user LIMIT #{offset}, #{limit}
</select>
```
其中,`offset`表示查询的起始位置,`limit`表示每页返回的记录数。
4. 在Service层或者Controller层中调用Mapper接口的方法进行分页查询。可以使用PageHelper或者手动计算分页参数。
使用PageHelper插件的示例代码如下:
```java
import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class UserService {
@Autowired
private UserMapper userMapper;
public List<User> getUsersByPage(int pageNum, int pageSize) {
PageHelper.startPage(pageNum, pageSize);
List<User> userList = userMapper.getUsersByPage();
PageInfo<User> pageInfo = new PageInfo<>(userList);
return pageInfo.getList();
}
}
```
手动计算分页参数的示例代码如下:
```java
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import java.util.List;
@Service
public class UserService {
@Autowired
private UserMapper userMapper;
public List<User> getUsersByPage(int pageNum, int pageSize) {
int offset = (pageNum - 1) * pageSize;
return userMapper.getUsersByPage(offset, pageSize);
}
}
```
这样就可以在Spring Boot项目中使用MyBatis进行分页查询了。
希望对你有所帮助!如果还有其他问题,请继续提问。
阅读全文