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);
    }

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

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

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

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

(0)
上一篇 2022年4月15日 上午9:20
下一篇 2022年4月15日 上午9:20


相关推荐

  • 文本数据标注工具doccano【介绍最详细的一遍文章】

    文本数据标注工具doccano【介绍最详细的一遍文章】向 AI 转型的程序员都关注了这个号 机器学习 AI 算法工程公众号 datayxdoccan 是一个开源文本标注工具 它提供了文本分类 序列标注和序列到序列的标注功能 因此 您可以为情绪分析 命名实体识别 文本摘要等创建标记数据 只需创建项目 上传数据并开始标注 总结下来就 3 步 上传数据 标注 下载带有标签的数据 官网 http doccano herokuapp

    2026年3月18日
    2
  • 光栅化插值方法

    光栅化插值方法光栅化方法详解 自己实现一个光栅化算法用以实现软渲染器

    2026年3月26日
    2
  • Csealed关键字

    Csealed关键字sealed 关键字用法概括

    2026年3月18日
    2
  • JavaScript经典案例:添加/删除元素类名

    JavaScript经典案例:添加/删除元素类名效果展示 CSS 代码 styletype text css btn wrapper width 300px height 100px text align center line height 100px margin 50pxauto background color FAEBD7 dis box width 300px height 50px text align center styletype text

    2026年3月17日
    3
  • Java 之 集合中的 modCount的作用「建议收藏」

    Java 之 集合中的 modCount的作用「建议收藏」modCount:记录当前集合被修改的次数在所有的集合实现类中(Collection与Map中),都会有一个 modCount 的变量出现,它的作用就是记录当前集合被修改的次数。下面以ArrayList 类进行说明:添加方法:删除方法:可以看出,两个操作都会影响元素的个数。 当我们使用迭代器或 foreach 遍历时,如果你在 foreach 遍历时,自动调用迭代器的迭代方法,此时在遍历过程中调用了集合的add,remove方法时,modCount就会改变,而迭代器记录的modCount

    2022年8月9日
    8
  • 毕业5年,我问遍了身边的大佬,总结了他们的学习方法

    毕业5年,我问遍了身边的大佬,总结了他们的学习方法我问了身边10个大佬,总结了他们的学习方法,原来成功都是有迹可循的。

    2022年6月10日
    27

发表回复

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

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