码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 8、Mybatis-Plus 分页插件、自定义分页


    第一篇:1、Mybatis-Plus 创建SpringBoot项目
    第二篇:2、Mybatis-Plus 测试增、删、改、查
    第三篇:3、Mybatis-Plus 自定义sql语句
    第四篇:4、Mybatis-Plus 通用service的操作
    第五篇:5、Mybatis-Plus 常用注解
    第六篇:6、Mybatis-Plus wrapper的使用
    第七篇:7、Mybatis-Plus condition的使用

    文章目录

    • 1、分页插件
      • 1.1、添加配置类
      • 1.2、测试
      • 1.3、测试结果
    • 2、XML自定义分页
      • 2.1、UserMapper中定义接口方法
      • 2.2、UserMapper.xml中编写SQL
      • 2.3、测试
      • 2.4、测试结果
      • 2.5、数据库中表数据

    1、分页插件

    1.1、添加配置类

    @Configuration
    //扫描mapper接口所在的包,可以将主类中的注解移到此处
    @MapperScan("com.zyz.mybatisplus.mapper")
    public class MyBatisPlusConfig {
    
        @Bean
        public MybatisPlusInterceptor mybatisPlusInterceptor(){
            MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();
            interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
            return interceptor;
        }
    
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13

    1.2、测试

    @Test
        public void testPage(){
            Page<User> page = new Page<>(2,3);
            userMapper.selectPage(page,null);
            System.out.println(page.getRecords());
            System.out.println(page.getPages());
            System.out.println(page.getTotal());
            System.out.println(page.hasNext());
            System.out.println(page.hasPrevious());
    
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    1.3、测试结果

    在这里插入图片描述

    2、XML自定义分页

    2.1、UserMapper中定义接口方法

    /**
         * 通过年龄查询用户信息并分页
         * @param page mybatis-plus 所提供的分页对象,必须位于第一个参数的位置
         * @param age
         * @return
         */
        Page<User> selectPageVo(@Param("page") Page<User> page,@Param("age") Integer age);
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    2.2、UserMapper.xml中编写SQL

    <!--    自定义分页 查询-->
        <select id="selectPageVo" resultType="User">
            select uid,user_name,age,email from t_user where age > #{age}
        </select>
    
    • 1
    • 2
    • 3
    • 4

    这里使用mybatis-plus中的起别名。需要在yml文件中进行配置

    spring:
    #  配置数据源信息
      datasource:
    #    配置数据源类型
        type: com.zaxxer.hikari.HikariDataSource
    #    配置连接数据库的各个信息
        username: root
        password: root
        url: jdbc:mysql://localhost:3306/mybatis_plus?allowMultiQueries=true&characterEncoding=UTF-8&characterSetResults=UTF-8&zeroDateTimeBehavior=convertToNull&useSSL=false
        driver-class-name: com.mysql.cj.jdbc.Driver
    
    
    server:
      port: 8383
    
    
    
    
    
    mybatis-plus:
      configuration:
        #配置Mybatis日志
        log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
    
    #设置mybatis-plus的全局配置:
      global-config:
        db-config:
          #设置实体类对应数据库中表的统一前缀
          table-prefix: t_
          #配置mybatis-plus的主键策略
          id-type: auto
       #配置类型别名所对应的包
      type-aliases-package: com.zyz.mybatisplus.pojo
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33

    在这里插入图片描述

    2.3、测试

    @Test
        public void testPageInDefine(){
            Page<User> page = new Page<>(2,3);
            userMapper.selectPageVo(page,22);
            System.out.println(page.getRecords());
            System.out.println(page.getPages());
            System.out.println(page.getTotal());
            System.out.println(page.hasNext());
            System.out.println(page.hasPrevious());
    
        }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    2.4、测试结果

    在这里插入图片描述

    2.5、数据库中表数据

    在这里插入图片描述

  • 相关阅读:
    uni-app的优缺点;uniapp进行条件编译的两种方法;小程序端和H5的代表值
    「SpringBoot」07 指标监控
    FreeRTOS教程8 任务通知
    软考 系统架构设计师系列知识点之软件架构风格(1)
    TensorFlow实战教程(二十五)-基于BiLSTM-CRF的医学命名实体识别研究(下)模型构建
    JavaScript(1)每天10个小知识点
    C# Fleck Socket
    数据结构与算法基础-(1)
    [kubernetes]二进制部署k8s集群-基于containerd
    渗透测试工具(3)Burpsuite
  • 原文地址:https://blog.csdn.net/weixin_43304253/article/details/126823785
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号