注:详细请看2.X博客中,3.X直接上代码。

建议装一个MybatisX插件,可以在Mapper和Xml来回切换

  • pom.xml

<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>3.2.0</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
<dependency>
<groupId>com.h2database</groupId>
<artifactId>h2</artifactId>
<scope>runtime</scope>
</dependency>

<dependency>
<groupId>com.alibaba</groupId>
<artifactId>fastjson</artifactId>
<version>1.2.49</version>
<scope>test</scope>
</dependency>
<!-- for testing -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
</dependencies>
  • 配置类

    @Configuration
    @MapperScan("com.mp.pagination.mapper")
    public class MybatisPlusConfig {

    /**
    * 分页插件
    */
    @Bean
    public PaginationInterceptor paginationInterceptor() {
    // 开启 count 的 join 优化,只针对 left join !!!
    return new PaginationInterceptor().setCountSqlParser(new JsqlParserCountOptimize(true));
    }
    }
  • application.yml

    # DataSource Config
    spring:
    datasource:
    driver-class-name: org.h2.Driver
    url: jdbc:h2:tcp://192.168.180.115:19200/~/mem/test
    username: root
    password: test

    # Logger Config
    logging:
    level:
    com.mp.pagination: debug

    mybatis-plus:
    mapper-locations: classpath:/mapper/*Mapper.xml
  • 实体类

    @Data
    public class Children {
    private Long id;
    private String name;
    private Long userId;
    }

    @Data
    public class User {
    private Long id;
    private String name;
    private Integer age;
    private String email;
    }
  • Dao层

    public interface UserMapper extends BaseMapper<User> {

    /**
    * 3.x 的 page 可以进行取值,多个入参记得加上注解
    * 自定义 page 类必须放在入参第一位
    * 返回值可以用 IPage<T> 接收 也可以使用入参的 MyPage<T> 接收
    * <li> 3.1.0 之前的版本使用注解会报错,写在 xml 里就没事 </li>
    * <li> 3.1.0 开始支持注解,但是返回值只支持 IPage ,不支持 IPage 的子类</li>
    *
    * @param myPage 自定义 page
    * @return 分页数据
    */
    // @Select("select * from user where (age = #{pg.selectInt} and name = #{pg.selectStr}) or (age = #{ps.yihao} and name = #{ps.erhao})")
    MyPage<User> mySelectPage(@Param("pg") MyPage<User> myPage, @Param("ps") ParamSome paramSome);


    @ResultMap("userChildrenMap")
    @Select("<script>select u.id,u.name,u.email,u.age,c.id as \"c_id\",c.name as \"c_name\",c.user_id as \"c_user_id\" " +
    "from user u " +
    "left join children c on c.user_id = u.id " +
    "<where>" +
    "<if test=\"selectInt != null\"> " +
    "and u.age = #{selectInt} " +
    "</if> " +
    "<if test=\"selectStr != null and selectStr != ''\"> " +
    "and c.name = #{selectStr} " +
    "</if> " +
    "</where>" +
    "</script>")
    MyPage<UserChildren> userChildrenPage(MyPage<UserChildren> myPage);


    MyPage<User> mySelectPageMap(@Param("pg") MyPage<User> myPage, @Param("map") Map param);

    List<User> mySelectMap(Map param);

    List<User> myPageSelect(MyPage<User> myPage);

    List<User> iPageSelect(IPage<User> myPage);

    List<User> rowBoundList(RowBounds rowBounds, Map map);
    }
  • model层

    @Data
    @Accessors(chain = true)
    @EqualsAndHashCode(callSuper = true)
    public class MyPage<T> extends Page<T> {
    private static final long serialVersionUID = 5194933845448697148L;

    private Integer selectInt;
    private String selectStr;
    private String name;

    public MyPage(long current, long size) {
    super(current, size);
    }
    }

    @Data
    @NoArgsConstructor
    @AllArgsConstructor
    public class ParamSome {

    private Integer yihao;
    private String erhao;
    }

    @Data
    @ToString(callSuper = true)
    @EqualsAndHashCode(callSuper = true)
    public class UserChildren extends User {

    private List<Children> c;
    }
  • 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" >
    <mapper namespace="com.mp.pagination.mapper.UserMapper">

    <resultMap id="userChildrenMap" type="com.mp.pagination.model.UserChildren">
    <id column="id" property="id"/>
    <result column="age" property="age"/>
    <result column="email" property="email"/>
    <result column="name" property="name"/>
    <collection property="c" ofType="com.mp.pagination.entity.Children" columnPrefix="c_">
    <id column="id" property="id"/>
    <result column="name" property="name"/>
    <result column="user_id" property="userId"/>
    </collection>
    </resultMap>

    <select id="mySelectPage" resultType="com.mp.pagination.entity.User">
    select *
    from user
    where (age = #{pg.selectInt} and name = #{pg.selectStr})
    or (age = #{ps.yihao} and name = #{ps.erhao})
    </select>

    <select id="mySelectPageMap" resultType="com.mp.pagination.entity.User">
    select * from user
    <where>
    <if test="map.name!=null and map.name!=''">
    name like #{map.name}
    </if>
    </where>
    </select>

    <select id="mySelectMap" resultType="com.mp.pagination.entity.User">
    select * from user
    <where>
    <if test="name!=null and name!=''">
    name like #{name}
    </if>
    </where>
    </select>

    <select id="myPageSelect" resultType="com.mp.pagination.entity.User">
    select * from user
    <where>
    <if test="name!=null and name!=''">
    name like '%'||#{name}||'%'
    </if>
    </where>
    </select>

    <select id="iPageSelect" resultType="com.mp.pagination.entity.User">
    select * from user
    <where>
    <if test="name!=null and name!=''">
    name like #{name}
    </if>
    </where>
    </select>

    <select id="rowBoundList" resultType="com.mp.pagination.entity.User">
    select * from user
    <where>
    <if test="name!=null and name!=''">
    name like #{name}
    </if>
    </where>
    </select>
    </mapper>
  • 测试类

    注:这里的MyPage对Page做了一层嵌套,其实一般不用,都是通过实体类的参数带到SQL中

    @RunWith(SpringRunner.class)
    @SpringBootTest
    class PaginationApplicationTests {

    @Resource
    private UserMapper mapper;

    @Test
    public void lambdaPagination() {
    Page<User> page = new Page<>(1, 3);
    QueryWrapper<User> wrapper = new QueryWrapper<>();
    wrapper.lambda().ge(User::getAge, 1).orderByAsc(User::getAge);
    IPage<User> result = mapper.selectPage(page, wrapper);
    System.out.println(result.getTotal());
    Assert.assertTrue(result.getTotal() > 3);
    Assert.assertEquals(3, result.getRecords().size());
    }

    @Test
    public void tests1() {
    System.out.println("----- baseMapper 自带分页 ------");
    Page<User> page = new Page<>(1, 5);
    IPage<User> userIPage = mapper.selectPage(page, new QueryWrapper<User>()
    .eq("age", 20).eq("name", "Jack"));
    // assertThat(page).isSameAs(userIPage);
    System.out.println("总条数 ------> " + userIPage.getTotal());
    System.out.println("当前页数 ------> " + userIPage.getCurrent());
    System.out.println("当前每页显示数 ------> " + userIPage.getSize());
    print(userIPage.getRecords());
    System.out.println("----- baseMapper 自带分页 ------");

    System.out.println("json 正反序列化 begin");
    String json = JSON.toJSONString(page);
    Page<User> page1 = JSON.parseObject(json, Page.class);
    print(page1.getRecords());
    System.out.println("json 正反序列化 end");

    System.out.println("----- 自定义 XML 分页 ------");
    MyPage<User> myPage = new MyPage<User>(1, 5).setSelectInt(20).setSelectStr("Jack");
    ParamSome paramSome = new ParamSome(20, "Jack");
    MyPage<User> userMyPage = mapper.mySelectPage(myPage, paramSome);
    //assertThat(myPage).isSameAs(userMyPage);
    System.out.println("总条数 ------> " + userMyPage.getTotal());
    System.out.println("当前页数 ------> " + userMyPage.getCurrent());
    System.out.println("当前每页显示数 ------> " + userMyPage.getSize());
    print(userMyPage.getRecords());
    System.out.println("----- 自定义 XML 分页 ------");
    }

    @Test
    public void tests2() {
    /* 下面的 left join 不会对 count 进行优化,因为 where 条件里有 join 的表的条件 */
    MyPage<UserChildren> myPage = new MyPage<>(1, 5);
    myPage.setSelectInt(18).setSelectStr("Jack");
    MyPage<UserChildren> userChildrenMyPage = mapper.userChildrenPage(myPage);
    List<UserChildren> records = userChildrenMyPage.getRecords();
    records.forEach(System.out::println);

    /* 下面的 left join 会对 count 进行优化,因为 where 条件里没有 join 的表的条件 */
    myPage = new MyPage<UserChildren>(1, 5).setSelectInt(18);
    userChildrenMyPage = mapper.userChildrenPage(myPage);
    records = userChildrenMyPage.getRecords();
    records.forEach(System.out::println);
    }

    private <T> void print(List<T> list) {
    if (!CollectionUtils.isEmpty(list)) {
    list.forEach(System.out::println);
    }
    }


    @Test
    public void testMyPageMap() {
    MyPage<User> myPage = new MyPage<User>(1, 5).setSelectInt(20).setSelectStr("Jack");
    Map map = new HashMap(1);
    map.put("name", "%a");
    mapper.mySelectPageMap(myPage, map);
    myPage.getRecords().forEach(System.out::println);
    }

    @Test
    public void testMap() {
    Map map = new HashMap(1);
    map.put("name", "%a");
    mapper.mySelectMap(map).forEach(System.out::println);
    }

    @Test
    public void myPage() {
    MyPage<User> page = new MyPage<>(1, 5);
    page.setName("a");
    mapper.myPageSelect(page).forEach(System.out::println);
    }

    @Test
    public void iPageTest() {
    IPage<User> page = new Page<User>(1, 5) {
    private String name = "%";

    public String getName() {
    return name;
    }

    public void setName(String name) {
    this.name = name;
    }
    };

    List<User> list = mapper.iPageSelect(page);
    System.out.println("list.size=" + list.size());
    System.out.println("page.total=" + page.getTotal());
    }

    @Test
    public void rowBoundsTest() {
    RowBounds rowBounds = new RowBounds(0, 5);
    Map map = new HashMap(1);
    map.put("name", "%");
    List<User> list = mapper.rowBoundList(rowBounds, map);
    System.out.println("list.size=" + list.size());
    }

    }
     

SpringBoot整合MybatisPlus3.X之分页插件(四)的更多相关文章

  1. SpringBoot-07:SpringBoot整合PageHelper做多条件分页查询

    ------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 本篇博客讲述如何在SpringBoot中整合PageHelper,如何实现带多个条件,以及PageInfo中的 ...

  2. SpringBoot整合PageHelper做多条件分页查询

    https://yq.aliyun.com/articles/619586 本篇博客讲述如何在SpringBoot中整合PageHelper,如何实现带多个条件,以及PageInfo中的属性的中文解释 ...

  3. SpringBoot整合MyBatis-Plus3.1详细教程

    作者:Sans_ juejin.im/post/5cfa6e465188254ee433bc69 一.说明 Mybatis-Plus是一个Mybatis框架的增强插件,根据官方描述,MP只做增强不做改 ...

  4. SpringBoot 整合Mybatis + PageHelper 实现分页

    前言: 现在公司大多数都实现了前后端分离,前端使用Vue.React.AngularJS 等框架,不用完全依赖后端.但是如果对于比较小型的项目,没必要前后端分离,而SpringBoot也基本抛弃了Js ...

  5. SpringBoot+MyBatis多数据源使用分页插件PageHelper

    之前只用过单数据源下的分页插件,而且几乎不用配置.一个静态方法就能搞定. PageHelper.startPage(pageNum, pageSize); 后来使用了多数据源(不同的数据库),Page ...

  6. springboot整合mybatis增删改查(四):完善增删改查及整合swgger2

    接下来就是完成增删改查的功能了,首先在config包下配置Druid数据连接池,在配置之前先把相关配置在application.preperties中完善 application.preperties ...

  7. SpringBoot整合MybatisPlus3.X之SQL执行分析插件(十四)

    pom.xml <dependencies> <dependency> <groupId>org.springframework.boot</groupId& ...

  8. 5、SpringBoot+MyBaits+Maven+Idea+pagehelper分页插件

    1.为了我们平时方便开发,我们可以在同一个idea窗口创建多个项目模块,创建方式如下 2.项目中pom.xm文件的内容如下 <?xml version="1.0" encod ...

  9. springboot整合es客户端操作elasticsearch(四)

    对文档查询,在实际开发中,对文档的查询也是偏多的,记得之前在mou快递公司,做了一套事实的揽件数据操作,就是通过这个来存储数据的,由于一天的数据最少拥有3500万数据 所以是比较多的,而且还要求查询速 ...

随机推荐

  1. Spring MVC-从零开始-view-forward、redirect

    1.forward或redirect后,不再走viewResolver过程,直接重新从控制器开始 2.代码 package com.jt; import org.springframework.ste ...

  2. spring系列常用注解

    常见注解使用 - @SpringBootApplication,springboot的核心注解,用于开启自动配置,等效于@Configuraion.@ComponentScan和@EnableAuto ...

  3. Java基础学习笔记(五) - 常用的API

    API介绍 概念:API 即应用编程程序接口.Java API是JDK中提供给我们使用的类说明文档,这些类将底层的代码实现封装.无需关心这些类是如何实现,只需要学习如何使用. 使用:通过API找到需要 ...

  4. Thinkphp5.0第三篇

    批量插入数据 //新增一条数据的方法 public function add() { /*$user =new UserModel(); $user->id=1; $user->name= ...

  5. Nginx简单介绍以及linux下使用Nginx进行负载均衡的搭建

    1.Nginx简介 Nginx是一款高性能的http 服务器/反向代理服务器及电子邮件(IMAP/POP3)代理服务器.由俄罗斯的程序设计师Igor Sysoev所开发,官方测试nginx能够支支撑5 ...

  6. vue路由跳转的方式

    vue路由跳转有四种方式 1. router-link 2. this.$router.push() (函数里面调用) 3. this.$router.replace() (用法同push) 4. t ...

  7. .Net下MoongoDB的简单调用

    1.安装.Net 驱动:Install-Package MongoDB.Driver 2.数据插入 //新建Person测试类 public class Person { public long Id ...

  8. JZOJ 3875 星球联盟

    [问题描述] 在遥远的 S 星系中一共有 N 个星球,编号为 1…N.其中的一些星球决定组成联盟, 以方便相互间的交流. 但是,组成联盟的首要条件就是交通条件.初始时,在这 N 个星球间有 M 条太空 ...

  9. 拿起键盘就是干:跟我一起徒手开发一套分布式IM系统

    1.引言 老读者应该还记得我在去年国庆节前分享过一篇<技术干货:从零开始,教你设计一个百万级的消息推送系统>,虽然我在文中有贴一些伪代码,依然有些朋友希望能直接分享一些可以运行的源码.好吧 ...

  10. Web前端安全之利用Flash进行csrf攻击

    整理于<XSS跨站脚本攻击剖析与防御>—第6章 Flash在客户端提供了两个控制属性: allowScriptAccess属性和allowNetworking属性,其中AllowScrip ...