前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >mybatis oracle 分页查询_oracle分页查询出现重复的问题

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

作者头像
全栈程序员站长
发布于 2022-11-08 12:18:27
发布于 2022-11-08 12:18:27
2.1K0
举报

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

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年9月22日 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
RowBounds分页原理、RowBounds的坑
项目中经常会使用分页查询,有次使用了RowBounds进行分页,因为很多场景或网上也看到很多这样的写法,所以我也在项目中使用了该类进行分页。但是有次线上却抛了异常,由此引发了对RowBounds原理的探究。
全栈程序员站长
2022/11/09
9370
java mybatis分页查询语句_mybatis分页查询的实现(一)[通俗易懂]
public List selectForPage1(int startIndex,int pageSize);
全栈程序员站长
2022/09/05
1.2K0
java中分页查询的实现_java中分页实现步骤图解
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
全栈程序员站长
2022/11/10
1.2K0
MyBatis 从入门到精通:分页在MyBatis中使用
本文介绍了MyBatis中分页技术的几种实现方式,包括使用Limit分页和RowBounds分页,以及分页插件的简要了解。
默 语
2024/11/20
1800
MyBatis 从入门到精通:分页在MyBatis中使用
原生分页查询原理步骤解析
    分页查询则是在页面上将本来很多的数据分段显示,每页显示用户自定义的行数。可提高用户体验度,     同时减少一次性加载,内存溢出风险。
上分如喝水
2021/08/16
1.3K0
原生分页查询原理步骤解析
Mybatis分页查询[通俗易懂]
分页查询作为数据库交互最常用的几种操作之一,在日常开发中是非常常见的,比如前段请求需要一个分页的列表,往往有两种方式,一是把所有的数据都给到前段,前段分页。另外一种方式是前端通过传分页信息给后端,后端查询时进行分页,并将相应页的数据返给前端。第一种方式如果数据规模比较小的情况下可以使用,如果数据量较大,对内存、网络传输的消耗都是非常大的,所以实际开发中一般很少使用。第二种方式是后端进行分页,后端分页的实现又可以分为逻辑分页和物理分页,逻辑分页就是在进行数据库查询时一次性将数据查出来,然后将相应页的数据挑出返回,物理分页就是通过在查询时就查询相应的页的数据(比如直接在mysql查询语句添加limit)。很明显逻辑分页跟第一种前端分页的方式有着相同的弊端。
全栈程序员站长
2022/09/05
3.4K0
springboot整合mybatis分页插件PageHelper实战
https://www.cnblogs.com/xifengxiaoma/p/11027551.html
全栈程序员站长
2022/11/03
1.5K0
mybatis的rowbounds是物理分页吗_rowbounds分页
在 mybatis 中,使用 RowBounds 进行分页,非常方便,不需要在 sql 语句中写 limit,即可完成分页功能。但是由于它是在 sql 查询出所有结果的基础上截取数据的,所以在数据量大的sql中并不适用,它更适合在返回数据结果较少的查询中使用
全栈程序员站长
2022/11/09
5020
mybatis的rowbounds是物理分页吗_rowbounds分页
MyBatis3-实现MyBatis分页
此文章中的例子是沿用上一篇文章http://www.cnblogs.com/EasonJim/p/7055499.html的Spring MVC集成的例子改装的。
林老师带你学编程
2019/05/25
1.4K0
JavaWeb之简单分页查询分析及代码
首先祝大家新年快乐,同样希望大家都可以健健康康的度过这次疫情,然后我想解释一下为什么停更长达一两个月,去年总是可能是熬夜生活作息不太规律,总是偏头痛,程度还挺重,已经影响自己的正常工作和学习,后来配合休息和药,才基本恢复了,上个学期末学校的事也是多了一些,很多时间都用在了课业或者看一些技术书上,所以停更了算挺久,非常抱歉,很感谢即使停更,大家也没有离我而去,从今天起,我接着开始更新一些文章,希望我粗浅的技术能给大家一些切实的帮助,非常欢迎大家用公众号后台,微信或者邮件的方式(文末有联系方式)与我交流,再次感谢大家!
BWH_Steven
2020/02/20
2.8K0
springboot集成mybatisplus分页_mybatis分页查询原理
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/194202.html原文链接:https://javaforall.cn
全栈程序员站长
2022/10/02
8090
用了这么久的PageHelper,你知道原生的分页查询原理和步骤吗
分页查询则是在页面上将本来很多的数据分段显示,每页显示用户自定义的行数。可提高用户体验度,同时减少一次性加载,内存溢出风险。
业余草
2021/12/06
2.2K0
用了这么久的PageHelper,你知道原生的分页查询原理和步骤吗
SpringBoot集成MyBatis的分页插件PageHelper(回头草)
       俗话说:好?不吃回头草,但是在这里我建议不管你是好马还是不好马,都来吃吃,带你复习一下分页插件PageHelper。               昨天给各位总结了本人学习springbo
赵小忠
2018/01/24
3.8K0
SpringBoot + mybatis 分页查询
com.github.pagehelper.PageHelper是一款好用的开源免费的Mybatis第三方分页插件。使用的时候,只要简单配置,就可以在查询语句之后得到所需的分页信息。
全栈程序员站长
2022/08/22
1.3K0
SpringBoot + mybatis 分页查询
ssm整合案例(超级详细)spring+springmvc+mybatis整合案例
spring+springmvc+mybatis整合案例 开发环境: 1、开发工具:eclipse 4.7.3 2、maven 3.5.2 3、jdk 1.9 4、tomcat 8.5 5、mysql 5.7.21 项目环境搭建: 1、创建项目: 打开eclipse,file --> new --> maven project --> maven archetype webapp,然后填写好artifactId,点finish即可。若是创建maven项目失败,请参考eclipse创建maven项目
贪挽懒月
2018/05/18
3.3K0
mybatis分页sql语句_MySQL 分页查询
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
全栈程序员站长
2022/11/09
4.5K0
mybatis分页sql语句_MySQL 分页查询
Java分页原理_分页系统原理
使用的是List接口中的subList(int startIndex, int endIndex)方法,返回列表中指定的fromIndex(包括)和endIndex(不包括)之间的部分视图。
全栈程序员站长
2022/11/09
2K0
Java分页原理_分页系统原理
mybatis oracle分页查询sql语句(oracle查询分页)
1.mysql中分页用limit,但是limit后面不能跟表达式 ,错误表达式:limit (1-1)*10,10。 2.对象中提供分页数据的方法。 备注:limit a,b 表示从第a+1条开始取,本次一共取b条 如limit 0,10:取第1-10条数据,如 limit 25,8:去第26-33条数据。
全栈程序员站长
2022/07/30
1.6K0
mybatis oracle分页查询sql语句(oracle查询分页)
tkmapper教程_tkr和tka的区别
tkmapper 中有对单表通用操作的封装,封装到Mapper接口和MySqlMapper接口;对单表操作,只需要自定义DAO接口继承Mapper接口和MySqlMapper接口即可
全栈程序员站长
2022/11/10
3470
mybatis流式查询
https://gitee.com/VampireAchao/simple-mybatis.git
阿超
2022/08/21
8050
mybatis流式查询
相关推荐
RowBounds分页原理、RowBounds的坑
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档