Mybatis实现Oracle 分页「建议收藏」

Mybatis实现Oracle 分页「建议收藏」Mybatis+Oracle分页1,使用mybatis的插件PageHelper(1)Mapper.xml<?xmlversion=”1.0″encoding=”UTF-8″?><!DOCTYPEmapperPUBLIC”-//mybatis.org//DTDMapper3.0//EN””http://mybatis.org/dtd/mybati…

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

Mybatis+Oracle 分页

1,使用mybatis的插件PageHelper

(1)Mapper.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">
<!-- namespace:填写的是监听的Mapper权限命名的接口 -->
<mapper namespace="cn.ssm.dao.StudentMapper">
	<select id="selectUserinfo"  resultType="cn.ssm.dao.bean.Userinfo">
	    select *  from userinfo
	</select>
</mapper>

(2)分页实现

	  public List<Userinfo> selectUserinfo() {
	 	  PageHelper.startPage(2, 3); //使用分页插件
		  List<Userinfo> userinfos =studentMapper.selectUserinfo();
		  PageInfo<Userinfo> infos=new PageInfo<Userinfo>(userinfos); 
		  List<Userinfo> list = infos.getList(); 
		  return userinfos; 
	  }

2,使用利用 rownum这个字段,oracle 数据库中特有的字段

(1)Mapper.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">
<!-- namespace:填写的是监听的Mapper权限命名的接口 -->
<mapper namespace="cn.ssm.dao.StudentMapper">
 <select id="selectUserinfo" parameterType="cn.ssm.dao.bean.Userinfo" resultType="cn.ssm.dao.bean.Userinfo">
      select * from ( select row_.*, rownum rownum_ from ( select * from  userinfo ) row_ 
      where rownum &lt;=  #{pageNum} * #{pageSize} ) where rownum_ &gt;  (#{pageNum} - 1) * #{pageSize}
  </select>
</mapper>

(2)分页实现

public class Userinfo {
	private int id;
	private String name;
	private String password;
	private Integer pageNum;
	private Integer pageSize;
}
	public List<Userinfo> selectUserinfo() {
		Userinfo user=new Userinfo();
				user.setPageNum(2);//设置当前为第2页
				user.setPageSize(3);//设置每页总共3条数据
		List<Userinfo> userinfos = studentMapper.selectUserinfo(user);
		return userinfos;
	}

结果展示:

Mybatis实现Oracle 分页「建议收藏」


例子:select * from (select t.*,rownum r from (select * from A) t where rownum < 10)where r >5
第一层:select * from A:要查询的数据
第二层:select t.*,rownum r from (select * from A) t where rownum < 10:取前 10 行
第三层:select * from (select t.*,rownum r from (select * from A) t where rownum < 10)where r >5:取 5-10 行


说明: select * from ( select row_.*, rownum rownum_ from ( select * from  userinfo ) row_  where rownum <=  #{pageNum} * #{pageSize} )a where rownum_ >  ( #{pageNum}- 1) * #{pageSize}
      
 解析:先查询select * from  userinfo 总条数并起个别名 row_,
        然后查询select row_.*, rownum rownum_ from ( select * from  userinfo ) row_  where rownum <=  #{pageNum} * #{pageSize} ,把所有数据和rownum固定字段列查询并起别名,
        最后从a中查询出想要的数据,主要是使用rownum固定字段列筛选实现分页 where rownum_ >  ( #{pageNum}- 1) * #{pageSize}


小于号:&lt;

大于号:&gt;

 

 

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

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

(1)
上一篇 2022年5月28日 下午1:36
下一篇 2022年5月28日 下午1:46


相关推荐

  • eBPF学习 – 入门

    eBPF学习 – 入门BPF和eBPF是什么?BPF是BerkeleyPacketFilter(伯克利数据包过滤器)得缩写,诞生于1992年,其作用是提升网络包过滤工具得性能,并于2014年正式并入Linux内核主线。BPF提供一种在各种内核事件和应用程序事件发生时允许运行一小段程序的机制,使得内核完全可编程,允许用户定制和控制他们的系统以解决相应的问题。BPF是一项灵活而高效的技术,由指令集、存储对象和辅助函数等几部分组成。其采用了虚拟指令集规范,运行时BPF模块提供两个执行机制:解释器和即时编译器(JIT)。在实际

    2026年2月11日
    7
  • DatabaseMetaData.getIndexInfo

    DatabaseMetaData.getIndexInfo示例通过DatabaseMetaData.getIndexInfo()获取索引信息。publicstaticvoidgetIndexInfo()throwsException{Connectionconn=getConnection();ResultSetrs=null;try{

    2022年6月19日
    26
  • navicat15 激活码【最新永久激活】

    (navicat15 激活码)最近有小伙伴私信我,问我这边有没有免费的intellijIdea的激活码,然后我将全栈君台教程分享给他了。激活成功之后他一直表示感谢,哈哈~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html09…

    2022年3月28日
    47
  • Linux的777权限

    Linux的777权限Linux 的每个文件一般都有三个权限 r 读 w 写 x 执行 其分别对应的数值为 4 2 1 输入 ll 可以查看到文件的权限 聪明的同学已经看出来了 7 即代表有读 写和执行的权限 那么为什么是三个 7 呢 三 是指三种不同的对象 User Gourp Other 即文件所有人 文件所有组 和其他人 Linux 修改 we 文件权限的命令为 chmodxxxfile

    2026年3月26日
    3
  • 零基础入门OpenClaw 完整安装配置实战指南(完全流程)

    零基础入门OpenClaw 完整安装配置实战指南(完全流程)

    2026年3月13日
    1
  • rpm 卸载软件_linux删除rpm卸载密码

    rpm 卸载软件_linux删除rpm卸载密码查看所有的java安装包rpm-qa|grepjava卸载安装包,忽略依赖rpm-e–nodepsopenjdkxxx

    2026年2月13日
    7

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号