栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

MybatisPlus 分页查询的实现

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

MybatisPlus 分页查询的实现

官网的文档描述的支持多个数据库支持 MySQL、MariaDB、Oracle、DB2、H2、HSQL、SQLite、Postgre、SQLServer 等多种数据库。

架构

源代码地gitee  mybatis-plus: mybatis 增强工具包,简化 CRUD 操作。 文档 http://baomidou.com

官网的文档:

分页插件 | MyBatis-Plus

pom文件




    4.0.0
    com.example
    demo
    0.0.1-SNAPSHOT
    demo
    Demo project for Spring Boot



    

        1.8
        UTF-8
        UTF-8
        2.3.7.RELEASE
    

    

        
            org.springframework.boot
            spring-boot-starter-web
        

        
            mysql
            mysql-connector-java
            runtime
        

        
            org.projectlombok
            lombok
            1.18.16
        

        
        
            org.springframework.boot
            spring-boot-devtools
            true
            true
        

        
            com.baomidou
            mybatis-plus-boot-starter
            3.4.3.4
        



        
            com.baomidou
            mybatis-plus-generator
            3.4.0
        



        
            org.freemarker
            freemarker
            2.3.30
        



        













        
            org.springframework.boot
            spring-boot-starter-test
            test
            
                
                    org.junit.vintage
                    junit-vintage-engine
                
            
        
    

    
        
            
                org.springframework.boot
                spring-boot-dependencies
                ${spring-boot.version}
                pom
                import
            
        
    

    
        
            
                org.apache.maven.plugins
                maven-compiler-plugin
                3.8.1
                
                    1.8
                    1.8
                    UTF-8
                
            

            

                org.springframework.boot
                spring-boot-maven-plugin
                2.3.7.RELEASE
                
                    com.example.demo.DemoApplication
                
                
                    
                        repackage
                        
                            repackage
                        
                    
                
            

            
                org.springframework.boot
                spring-boot-maven-plugin
                2.4.0
                
                    true
                
            

            
                org.springframework.boot
                spring-boot-maven-plugin
                
                    true
                
            
        

    



数据表



SET FOREIGN_KEY_CHECKS=0;



-- ----------------------------

-- Table structure for test

-- ----------------------------

DROP TABLE IF EXISTS `test`;

CREATE TABLE `test` (

  `id` bigint(20) NOT NULL AUTO_INCREMENT,

  `name` varchar(255) DEFAULT NULL,

  `age` int(11) DEFAULT NULL,

  PRIMARY KEY (`id`)

) ENGINE=InnoDB AUTO_INCREMENT=13 DEFAULT CHARSET=utf8;



-- ----------------------------

-- Records of test

-- ----------------------------

INSERT INTO `test` VALUES ('1', 'z', '1');

INSERT INTO `test` VALUES ('2', 'z', '2');

INSERT INTO `test` VALUES ('3', 'z', '3');

INSERT INTO `test` VALUES ('4', 'z', '4');

INSERT INTO `test` VALUES ('5', 'z', '5');

INSERT INTO `test` VALUES ('6', 'z', '6');

INSERT INTO `test` VALUES ('7', 'z', '7');

INSERT INTO `test` VALUES ('8', 'z', '8');

INSERT INTO `test` VALUES ('9', 'z', '9');

INSERT INTO `test` VALUES ('10', 'z', '10');

INSERT INTO `test` VALUES ('11', 'z', '11');

INSERT INTO `test` VALUES ('12', 'z', '12');

配置文件application.properties
# 应用名称
spring.application.name=demo
#应用服务 WEB 访问端口
server.port=8094
# 数据库驱动:
spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver
# 数据库连接地址
spring.datasource.url=jdbc:mysql://192.168.0.197:3306/test?serverTimezone=Asia/Shanghai&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull
# 数据库用户名&密码:
spring.datasource.username=root
spring.datasource.password=123213

启动类
package com.example.demo;

import org.mybatis.spring.annotation.MapperScan;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;


@SpringBootApplication
@MapperScan("com.example.demo.mapper")
public class DemoApplication {

    public static void main(String[] args) {
        System.out.println("123大苏sss打");
        SpringApplication.run(DemoApplication.class, args);
    }
}

新建po
package com.example.demo.po;



import com.baomidou.mybatisplus.annotation.IdType;

import com.baomidou.mybatisplus.annotation.TableId;

import java.io.Serializable;

import lombok.Data;

import lombok.EqualsAndHashCode;





@Data

@EqualsAndHashCode(callSuper = false)

public class Test implements Serializable {

    private static final long serialVersionUID = 1L;

    @TableId(value = "id", type = IdType.AUTO)

    private Long id;

    private String name;

    private Integer age;

}

新建Mapper
package com.example.demo.mapper;



import com.example.demo.po.Test;

import com.baomidou.mybatisplus.core.mapper.baseMapper;





public interface TestMapper extends baseMapper {



}

新建service
package com.example.demo.service;



import com.baomidou.mybatisplus.core.metadata.IPage;

import com.example.demo.po.Test;

import com.baomidou.mybatisplus.extension.service.IService;

import com.fulong.portal.open5dServer.common.utils.PageInfo;





public interface ITestService extends IService {

    IPage getProjectTableI(Integer pageNo, Integer pageSize, String name, int age);

}

新建ServiceImpl
package com.example.demo.service.impl;



import com.baomidou.mybatisplus.core.metadata.IPage;

import com.baomidou.mybatisplus.core.toolkit.Wrappers;

import com.baomidou.mybatisplus.extension.plugins.pagination.Page;

import com.example.demo.po.PTreeFolder;

import com.example.demo.po.Test;

import com.example.demo.mapper.TestMapper;

import com.example.demo.service.ITestService;

import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;

import com.fulong.portal.open5dServer.common.utils.PageInfo;

import org.springframework.stereotype.Service;



import javax.annotation.Resource;

import java.util.Optional;



@Service

public class TestServiceImpl extends ServiceImpl implements ITestService {



    @Resource

    TestMapper testMapper;



    @Override

    public IPage getProjectTableI(Integer pageNo, Integer pageSize, String name, int age) {

        IPage iPage = new Page(Optional.ofNullable(pageNo).orElse(0), pageSize);

        IPage list = testMapper.selectPage(iPage, Wrappers.lambdaQuery()

                .eq(true,Test::getName, name).eq(true,Test::getAge,age));

        return list;

    }

}

最后在controller里调用
  @PostMapping(value = "getProjectTestI")

    public IPage getProjectTestI(Integer pageNo, Integer pageSize, String name, int age){

        return iTestService.getProjectTableI(pageNo,pageSize,name,age);

}

最后忘了添加分页配置文件
package com.example.demo;



import com.baomidou.mybatisplus.annotation.DbType;

import com.baomidou.mybatisplus.extension.plugins.MybatisPlusInterceptor;

import com.baomidou.mybatisplus.extension.plugins.PaginationInterceptor;

import com.baomidou.mybatisplus.extension.plugins.inner.PaginationInnerInterceptor;

import org.mybatis.spring.annotation.MapperScan;

import org.springframework.context.annotation.Bean;

import org.springframework.context.annotation.Configuration;





@Configuration

@MapperScan("com.example.demo.mapper")

public class MybatisPlusConfig {

    

//    @Bean

//    public PaginationInterceptor paginationInterceptor() {

//        return new PaginationInterceptor();

//    }



    // 最新版

    @Bean

    public MybatisPlusInterceptor mybatisPlusInterceptor() {

        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();

        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.H2));

        return interceptor;

    }

}

测试

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/353552.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号