mybatis oracle 分页查询_oracle分页查询出现重复的问题

大家好,又见面了,我是你们的朋友全栈君。

Oracle中分页查询因为存在伪列rownum,sql语句写起来较为复杂,现在介绍一种通过使用MyBatis中的RowBounds进行分页查询,非常方便。

使用MyBatis中的RowBounds进行分页查询时,不需要在 sql 语句中写 offset,limit,mybatis 会自动拼接 分页sql ,添加 offset,limit,实现自动分页。

需要前台传递参数currentPage和pageSize两个参数,分别是当前页和每页数量,controller层把参数传递给service层即可,下面是service实现的代码:

package com.xyfer.service.impl;

import java.util.HashMap;

import java.util.List;

import java.util.Map;

import org.apache.ibatis.session.RowBounds;

import com.xyfer.dao.UserDao;

import com.xyfer.service.UserService;

public class UserServiceImpl implements UserService {

private UserDao userDao;

@Override

public Map queryUserList(String currentPage, String pageSize) {

//查询数据总条数

int total = userDao.queryCountUser();

//返回结果集

Map resultMap = new HashMap();

resultMap.put(“total”, total);

//总页数

int totalpage = (total + Integer.parseInt(pageSize) – 1) / Integer.parseInt(pageSize);

resultMap.put(“totalpage”, totalpage);

//数据的起始行

int offset = (Integer.parseInt(currentPage)-1)*Integer.parseInt(pageSize);

RowBounds rowbounds = new RowBounds(offset, Integer.parseInt(pageSize));

//用户数据集合

List> userList = userDao.queryUserList(rowbounds);

resultMap.put(“userList”, userList);

return resultMap;

}

}

dao层接口:

package com.xyfer.dao;

import java.util.List;

import java.util.Map;

import org.apache.ibatis.session.RowBounds;

public interface UserDao {

public int queryCountUser(); //查询用户总数

public List> queryUserList(RowBounds rowbounds); //查询用户列表

}

对应的mapper.xml文件:

/p>

PUBLIC “-//mybatis.org//DTD Mapper 3.0//EN”

“http://mybatis.org/dtd/mybatis-3-mapper.dtd”>

select count(1) from user

select * from user

通过postman调用接口,传入对应的参数,即可实现分页查询数据。

总结

以上所述是小编给大家介绍的Oracle使用MyBatis中RowBounds实现分页查询功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我们网站的支持!

如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

时间: 2019-07-17

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/190756.html原文链接:https://javaforall.cn