mybatis oracle分页查询sql语句(oracle查询分页)

java实现mysql分页查询1.前言1.mysql中分页用limit,但是limit后面不能跟表达式,错误表达式:limit(1-1)*10,10。2.对象中提供分页数据的方法。备注:limita,b表示从第a+1条开始取,本次一共取b条如limit0,10:取第1-10条数据,如limit25,8:去第26-33条数据。application.properties数据库Mysql配置#数据库配置spring.datasource.url=jdbc:mysql://loc

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

java实现mysql分页查询

1.前言

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条数据。

application.properties数据库Mysql配置

#数据库配置
spring.datasource.url=jdbc:mysql://localhost:3306/xxxxxx?serverTimezone=UTC
spring.datasource.username= xxxx
spring.datasource.password= xxxx
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

#mybatis的mapper书写路径
mybatis.mapper-locations=classpath:mapper/*/*.xml 

pom依赖

		<dependency>
            <groupId>org.mybatis.spring.boot</groupId>
            <artifactId>mybatis-spring-boot-starter</artifactId>
            <version>2.1.2</version>
        </dependency>

        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <scope>runtime</scope>
        </dependency>

2.java分页对象类

分页对象: 主要看pageNo 、pageSize 、startNum,这里给页码和条数附初始值。有@Data在可以自动实现set和get

import lombok.Data;
import java.util.Date;

@Data
public class BaseModel { 
   
    /** * 上游系统唯一系统标识号 12位系统号 **/
    private String upSystemId;
    /** * 上游系统唯一流水号 21位 **/
    private String upSystemSeqNo;
    /** * 上游系统 请求日期 2020-10-20 **/
    private Date tranDate;
    /** * 上游系统 操作人 12位 **/
    private String userId;
    /** * 主键ID **/
    private String id;
    /** * 创建时间 **/
    private Date createTime;
    /** * 更新时间 **/
    private Date updateTime;

    /** * 当前页,需要查询的页数 * pageNo从1开始 */
    private int pageNo = 0;

    /** * 每页显示的条数 */
    private int pageSize = 10;

    /** * 当前页,需要查询的页数 * pageNo从1开始 */
    private int startNum;

    /** * 设置分页查询数据 */
    public void setPageQuery() { 
   
        this.startNum = this.getPageNo() > 0 ? (this.getPageNo() - 1) * this.getPageSize() : 0;
    }

在调用sql前,设置分页数据:model.setPageQuery();
备注:该对象继承了BaseModel ,所以子类可以直接调用父类的方法。

	@BaseBeforeAnnotation
    @RequestMapping("selectReaderCardList")
    public BaseResponse selectReaderCardList(@RequestBody ReaderCardInfoModel model) { 
   
        model.setPageQuery();
        List<ReaderCardInfoModel> bookInfoModel = readerCardInfoService.selectReaderCardList(model);
        return new BaseResponse(ResultEnum.SUCCESS,bookInfoModel);
    }

3. Mybatis–Mapping.xml

mapping.xml中的分页查询sql:
主要看这段,pageNo>0表示是分页查询,不是全量查询。
startNum表示从第startNum+1条数据开始取数据,startNum在setPageQuery()方法中赋值了。
pageSize表示取多少条数据。

<if test="pageNo > 0">
      limit #{ 
   startNum}, #{ 
   pageSize}
</if>
    <select id="selectReaderCardList" parameterType="com.example.demo.executer.readerCardInfo.model.ReaderCardInfoModel"
            resultMap="BaseResultMap">
        select id,
               reader_id,
               usable_flag,
               card_amt,
               bind_date,
               remark,
               create_time,
               update_time
        from t_reader_card
        <where>
            <if test="usableFlag != null">
                and usable_flag = #{ 
   usableFlag}
            </if>
            <if test="bindDate != null">
                and bind_date = #{ 
   bindDate}
            </if>
            <if test="readerId != null">
                and reader_id = #{ 
   readerId}
            </if>
        </where>
        order by create_time desc
        <if test="pageNo > 0">
            limit #{ 
   startNum}, #{ 
   pageSize}
        </if>
    </select>

4.请求与执行结果

postman请求参数
查询第3页的4条数据,limit 8,4
在这里插入图片描述

管理台日志打印
后台在接收到请求时,生成ReaderCardInfoController对象时,会自动生成

 : ----------------------------------------------------------------------------------------------------start
 : ------BaseBeforeAspect---获取到请求参数------
 : ---入口方法:com.example.demo.executer.readerCardInfo.controller.ReaderCardInfoController
 : ---请求方法:selectReaderCardList
 : ---请求参数:{ 
   "pageNo":3,"pageSize":4,"startNum":0,"usableFlag":"0"}
 : ==>  Preparing: select id, reader_id, usable_flag, card_amt, bind_date, remark, create_time, update_time from t_reader_card WHERE usable_flag = ? order by create_time desc limit ?, ?
 : ==> Parameters: 0(String), 8(Integer), 4(Integer)
 : <==      Total: 4
 : ---commonAfter返回参数:
 { 
   "code":"000000","data":[
 { 
   "createTime":1603295662000,"id":"202010211554221000048","pageNo":0,"pageSize":10,"remark":"新建卡","startNum":0,"updateTime":1603295662000},
 { 
   "createTime":1603295662000,"id":"202010211554221000049","pageNo":0,"pageSize":10,"remark":"新建卡","startNum":0,"updateTime":1603295662000},
 { 
   "createTime":1603295661000,"id":"202010211554211000045","pageNo":0,"pageSize":10,"remark":"新建卡","startNum":0,"updateTime":1603295661000},
 { 
   "createTime":1603295661000,"id":"202010211554211000046","pageNo":0,"pageSize":10,"remark":"新建卡","startNum":0,"updateTime":1603295661000}
 ],"msg":"交易成功"}
 : ----------------------------------------------------------------------------------------------------end"}
: ----------------------------------------------------------------------------------------------------end

扩展

有个想法,不想再方法中调用model.setPageQuery(),想自动完成这个步骤。
分页对象写成以下两种,并在调用处去掉model.setPageQuery();

    /** * 当前页,需要查询的页数 * pageNo从1开始 */
    private int startNum = this.getPageNo() > 0 ? (this.getPageNo() - 1) * this.getPageSize() : 0;
// private int startNum = 0;
    /** * 设置分页查询数据 */
    public void setPageQuery() { 
   
        this.startNum = this.getPageNo() > 0 ? (this.getPageNo() - 1) * this.getPageSize() : 0;
    }

    public BaseModel(){ 
   
        setPageQuery();
    }
	@BaseBeforeAnnotation
    @RequestMapping("selectReaderCardList")
    public BaseResponse selectReaderCardList(@RequestBody ReaderCardInfoModel model) { 
   
       // model.setPageQuery();
        List<ReaderCardInfoModel> bookInfoModel = readerCardInfoService.selectReaderCardList(model);
        return new BaseResponse(ResultEnum.SUCCESS,bookInfoModel);
    }

结果是:不得行。嘿嘿,暂时未想到好的方法。

此分页方法是自己结合公司项目写的,有不足的地方欢迎大家指正。

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

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/129338.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • 微信小程序地图实时定位_小程序获取当前位置定位信息

    微信小程序地图实时定位_小程序获取当前位置定位信息小程序获取当前位置,回到当前位置,地图定位,导航效果因为小程序更新了获取地理位置API接口,需要先在app.json中配置一下permission字段,不然会报微信小程序getLocation需要在app.json中声明permission字段app.json:(不知道具体位置可以看这里,这里有整个app.json的配置)”permission”:{…

  • 插头DP小结_dp插头接线标准

    插头DP小结_dp插头接线标准插头DP一般都是棋盘模型,找路径或者环路最值或者方案数。插头:说白了就是两个联通的格子,一个走向另一个,那么这里就有一个插头。轮廓线:DP逐格DP,那么轮廓线可以分开DP过的格子和未DP的格子。轮廓线的长度明显是m+1。插头垂直于轮廓线。转移:轮廓线在换行的时候要位移,这个画画图就出来了。然后具体问题具体讨论。比如任意多个环路,不考虑方向,那么就是eatthetrees,用最

    2022年10月28日
  • Java基础语法(十一)类?对象?我能不能写个妹子类给自己造个(一个够吗?)对象?

    Java基础语法(十一)类?对象?我能不能写个妹子类给自己造个(一个够吗?)对象?

  • java中级考试 考点_java中级面试题的考点「建议收藏」

    java中级考试 考点_java中级面试题的考点「建议收藏」在我们对java有一定的基础学习后,能力再往上升一些就是中级。对于初级和中级来说,后者除了对于基础java内容把握能力强外,在一些知识点的比较分析和原理解剖上有所理解能力。本篇就java中级面试题进行了整理,挑出了一些典型的高频试题,都来看看具体内容吧。1.比较接口和抽象类的语法区别(1)抽象类可以有构造方法,接口中不能有构造方法。(2)抽象类中可以有普通成员变量,接口中没有普通成员变量!!!(注…

    2022年10月10日
  • 挖矿病毒攻击的排查处置手册

    挖矿病毒攻击的排查处置手册一、背景在用户不知情或未经允许的情况下,占用系统资源和网络资源进行挖矿,影响用户的网络和资源,从而获取虚拟币牟利。为了帮助应对恶意挖矿程序攻击,发现和清除恶意挖矿程序,防护和避免感染恶意挖矿程序,整理了如下针对挖矿活动相关的现状分析和检测处置建议。二、为什么会感染恶意挖矿程序通常遇到企业内网主机感染恶意挖矿程序,或者网站、服务器以及使用的云服务被植入恶意挖矿程序的时候,都不免提出“为什么会感染恶意挖矿程序,以及是如何感染的”诸如此类的问题,目前感染恶意挖矿程序的主要方式:2.1.利用类似其他病毒木

  • 树莓派能做什么呢?如何使用树莓派

    树莓派能做什么呢?如何使用树莓派我们知道树莓派是最常用的开发板,树莓派受欢迎的原因之一在于树莓派的功能非常全面,不论是做视频播放、音频播放等功能,树莓派都能派上用场。为增进大家对树莓派的认识,本文将带大家了解一下曾有人用树莓派做了什么。如果你对树莓派具有兴趣,不妨继续往下阅读哦。1、无线热点这大概是地球人拿来干的最多的一件——插上网线和USB无线网卡,配置之后就可以作为一个无线热点。2、机械假肢MITMediaLab的研究员把它作为机械假肢的控制器。3、简易自制笔记本把树莓派跟LCD液晶面板连上,再加上鼠标键盘

发表回复

您的电子邮箱地址不会被公开。

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