返回顶部
首页 > 资讯 > 数据库 >MyBatis-Plus联表查询及分页
  • 486
分享到

MyBatis-Plus联表查询及分页

mybatismysqljava 2023-08-16 21:08:02 486人浏览 泡泡鱼
摘要

mybatis-Plus联表查询及分页 一、准备工作1、数据库结构以及数据2、依赖3、配置类让mybatis-plus-join在DataScopeSqlInjector中生效4、启动类排除MPJSqlInjector.class


一、准备工作

mybatis-plus作为mybatis的增强工具,它的出现极大的简化了开发中的数据库操作,但是长久以来,它的联表查询能力一直被大家所诟病。一旦遇到left joinright join的左右连接,你还是得老老实实的打开xml文件,手写上一大段的sql语句。

直到前几天,偶然碰到了这么一款叫做mybatis-plus-join的工具(后面就简称mpj了),使用了一下,不得不说真香!彻底将我从xml地狱中解放了出来,终于可以以类似mybatis-plusQueryWrapper的方式来进行联表查询了,话不多说,我们下面开始体验。

  • mapper继承MPJBaseMapper (必选)
  • service继承MPJBaseService (可选)
  • serviceImpl继承MPJBaseServiceImpl (可选)

1、数据库结构以及数据

CREATE TABLE `op_product` (  `id` int(11) NOT NULL AUTO_INCREMENT,  `type` varchar(255) DEFAULT NULL,  PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8;INSERT INTO `test_yjdsns`.`op_product`(`id`, `type`) VALUES (1, '苹果');CREATE TABLE `op_product_info` (  `id` int(11) NOT NULL AUTO_INCREMENT,  `product_id` int(11) NOT NULL,  `name` varchar(255) DEFAULT NULL,  `price` decimal(10,2) DEFAULT NULL,  PRIMARY KEY (`id`)) ENGINE=InnoDB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;INSERT INTO `test_yjdsns`.`op_product_info`(`id`, `product_id`, `name`, `price`) VALUES (1, 1, '苹果13', 8.00);INSERT INTO `test_yjdsns`.`op_product_info`(`id`, `product_id`, `name`, `price`) VALUES (2, 1, '苹果15', 9.00);

2、依赖

    com.GitHub.yulichang    mybatis-plus-join    1.2.4    com.baomidou    mybatis-plus-boot-starter    3.5.1

3、配置类让mybatis-plus-join在DataScopeSqlInjector中生效

@Configurationpublic class MybatisPlusConfig {        @Bean    public MybatisPlusInterceptor mybatisPlusInterceptor() {        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();        //分页插件        interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.Mysql));        return interceptor;    }        @Bean    @Primary    public mysqlInjector myLogicSqlInjector() {        return new MySqlInjector();    }}

修改DataScopeSqlInjector中的继承类为:MPjsqlInjector

public class MySqlInjector extends MPJSqlInjector {    @Override    public List getMethodList(Class mapperClass) {        //将原来的保持        List methodList = super.getMethodList(mapperClass);        //多表查询sql注入 从连表插件里移植过来的        methodList.add(new SelectJoinOne());        methodList.add(new SelectJoinList());        methodList.add(new SelectJoinPage());        methodList.add(new SelectJoinMap());        methodList.add(new SelectJoinMaps());        methodList.add(new SelectJoinMapsPage());        return methodList;    }}

4、启动类排除MPJSqlInjector.class

@SpringBootApplication(exclude = {MPJSqlInjector.class})

载入自定义配置类

@Configuration

@MapperScan可以选择tk下的路径

import tk.mybatis.spring.annotation.MapperScan;

在这里插入图片描述

二、代码

1、实体类

@Data@NoArgsConstructor@AllArgsConstructor@TableName("op_product")public class OpProduct implements Serializable {    private static final long serialVersionUID = -3918932563888251866L;    @TableId(value = "ID", type = IdType.AUTO)    private Long id;    @TableField("TYPE")    private String type;}
@Data@NoArgsConstructor@AllArgsConstructor@TableName("op_product_info")public class OpProductInfo implements Serializable {    private static final long serialVersionUID = 4186082342917210485L;    @TableId(value = "ID", type = IdType.AUTO)    private Long id;    @TableField("PRODUCT_ID")    private Long productId;    @TableField("NAME")    private String name;    @TableField("PRICE")    private Double price;}
@Data@NoArgsConstructor@AllArgsConstructorpublic class ProductDTO implements Serializable {    private static final long serialVersionUID = -2281333877153304329L;    private Long id;    private String type;    private String name;    private Double price;}

2、Mapper

public interface OpProductInfoMapper extends MPJBaseMapper {}
public interface OpProductMapper extends MPJBaseMapper {}

3、Service

Mapper接口改造完成后,我们把它注入到Service中,虽然说我们要完成3张表的联表查询,但是以OpProduct作为主表的话,那么只注入这一个对应的OpProductMapper就可以,非常简单。

public interface OpProductService extends MPJBaseService {    List queryAllProduct();}
@Service@Slf4j@AllArgsConstructorpublic class OpProductServiceImpl extends MPJBaseServiceImpl implements OpProductService {    @Resource    private OpProductMapper opProductMapper;    @Override    public List queryAllProduct() {        MPJLambdaWrapper mpjLambdaWrapper = new MPJLambdaWrapper()                .selectAll(OpProduct.class)//查询表1的全部字段                .selectAll(OpProductInfo.class)//查询表2的全部字段                .leftJoin(OpProductInfo.class, OpProductInfo::getProductId, OpProduct::getId);//左查询表2条件为表二的productId=表一的id        List list = opProductMapper.selectJoinList(ProductDTO.class, mpjLambdaWrapper);        return list;    }}

4、测试

@SpringBootTest@Slf4jpublic class MybatisJoinTests {    @Autowired    private OpProductService opProductService;        @Test    void test1() {        List productDTOS = opProductService.queryAllProduct();        log.info(productDTOS.toString());    }}

5、结果

在这里插入图片描述

三、分页查询

1、MPJLambdaWrapper几个方法

接下来的MPJLambdaWrapper就是构建查询条件的核心了,看一下我们在上面用到的几个方法:

  • selectAll():查询指定实体类的全部字段
  • select():查询指定的字段,支持可变长参数同时查询多个字段,但是在同一个select中只能查询相同表的字段,所以如果查询多张表的字段需要分开写
  • selectAs():字段别名查询,用于数据库字段与接收结果的dto中属性名称不一致时转换
  • leftJoin():左连接,其中第一个参数是参与联表的表对应的实体类,第二个参数是这张表联表的ON字段,第三个参数是参与联表的ON的另一个实体类属性

除此之外,还可以正常调用mybatis-plus中的各种原生方法,文档中还提到,默认主表别名是t,其他的表别名以先后调用的顺序使用t1、t2、t3以此类推。

和mybatis-plus非常类似,除了LamdaWrapper外还提供了普通QueryWrapper的写法,举例代码:

public void getOrderSimple() {     List list = xxxxxMapper.selectJoinList(xxxxx.class,     new MPJqueryWrapper()      .selectAll(xxxxx.class)      .select("t2.unit_price","t2.name as product_name")      .select("t1.name as user_name")      .leftJoin("t_user t1 on t1.id = t.user_id")      .leftJoin("t_product t2 on t2.id = t.product_id")      .eq("t.status", "3")    );        log.info(list.toString());}

或者

        MPJLambdaWrapper mpjLambdaWrapper = new MPJLambdaWrapper()                .selectAll(OpProduct.class)//查询表1的全部字段                .selectAs(OpProductInfo::getId,"ProductInfoId")//起别名                .selectAs(OpProductInfo::getName,ProductDTO::getName)//起别名                .selectAs(OpProductInfo::getPrice,ProductDTO::getPrice)//起别名                .leftJoin(OpProductInfo.class, OpProductInfo::getProductId, OpProduct::getId);//左查询表2条件为表二的productId=表一的id        List list = opProductMapper.selectJoinList(ProductDTO.class, mpjLambdaWrapper);        return list;

在这里插入图片描述

2、分页代码举例

    public IPage queryPageProduct(Integer pageNo, Integer pageCount) {        MPJLambdaWrapper mpjLambdaWrapper = new MPJLambdaWrapper()                .selectAll(OpProduct.class)//查询表1的全部字段                .selectAll(OpProductInfo.class)//查询表2的全部字段                .leftJoin(OpProductInfo.class, OpProductInfo::getProductId, OpProduct::getId);//左查询表2条件为表二的productId=表一的id        IPage page = opProductMapper.selectJoinPage(new Page(pageNo, pageCount), ProductDTO.class, mpjLambdaWrapper);        return page;    }

在这里插入图片描述

来源地址:https://blog.csdn.net/weixin_46146718/article/details/125279384

您可能感兴趣的文档:

--结束END--

本文标题: MyBatis-Plus联表查询及分页

本文链接: https://lsjlt.com/news/372154.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • MyBatis-Plus联表查询及分页
    MyBatis-Plus联表查询及分页 一、准备工作1、数据库结构以及数据2、依赖3、配置类让mybatis-plus-join在DataScopeSqlInjector中生效4、启动类排除MPJSqlInjector.class ...
    99+
    2023-08-16
    mybatis mysql java
  • mybatis-plus 多表关联条件分页查询
    此处以一对多,条件分页查询为例: 一.表结构: 主表 CREATE TABLE `t_user` ( `id` bigint NOT NULL AUTO_INCREMENT, `user_name` varchar(255) DEFAU...
    99+
    2023-08-20
    mybatis mysql java
  • Mybatis Plus一对多联表查询及分页解决方案
    文章目录 需求需求分析分页问题说明分页问题原因一对多场景一一对多场景二性能优化优化解决方案 需求 查询用户信息列表,其中包含用户对应角色信息,页面检索条件有根据角色名称查询用户列...
    99+
    2023-10-22
    mybatis java 开发语言
  • Mybatis-Plus分页查询
    分页插件 调用通用mapper提供的selectPage分页方法; 2、自定义查询方法使用分页功能:     - mapper接口中的方法返回值是Page类型     - 第一个参数要求是Page类型 3、映射文件中可以使用sql标签定义公...
    99+
    2023-08-31
    mybatis java mysql
  • spring boot集成mybatis-plus——Mybatis Plus 多表联查(包含分页关联查询,图文讲解)...
    Mybatis Plus 多表联查(包含分页关联查询,图文讲解)  更新时间 2023-01-03 21:41:38 大家好,我是小哈。 本小节中,我们将学习如何通过 Mybatis Plus 实现多表关联查询,以及...
    99+
    2023-08-31
    mybatis spring boot java 数据库 mysql
  • MyBatis-Plus 分页查询以及自定义sql分页
    一、引言 分页查询每个人程序猿几乎都使用过,但是有部分同学不懂什么是物理分页和逻辑分页。 物理分页:相当于执行了limit分页语句,返回部分数据。物理分页只返回部分数据占用内存小,能够获取数据库最新的状态,实施性比较强,一般适用于数据量比较...
    99+
    2023-09-01
    mybatis sql mysql
  • Mybatis-Plus——分页+模糊查询
    建表:  create table pms_brand( brand_id bigint not null auto_increment comment '品牌id', name ...
    99+
    2023-09-22
    mybatis mysql
  • Mybatis-Plus实现分页查询
    Mybatis-Plus实现分页查询 文章目录 Mybatis-Plus实现分页查询1.1技术概述1.2技术详述1.2.1配置分页插件1.2.2自定义分页1、如果你的mapper没有继承BaseMapper2、如果你的mapper继...
    99+
    2023-08-17
    mybatis java spring boot
  • mybatis plus 分页查询出现count()
    出现问题现象 使用mybatisplus分页时候count语句出错,控制台打印的sql为### The error may involve defaultParameterMap, The error occurred while sett...
    99+
    2023-08-17
    mybatis java mysql
  • Mybatis-plus多表查询
    如题有一个用户表,有一个订单表,此时你想查询用户的时候把他附属的订单也查到 一对多 user pojo package com.suse.entity;import com.baomidou.myba...
    99+
    2023-09-09
    mybatis java mysql
  • mybatis-plus分页查询三种方法
    mybatis-plus分页查询 一、前期准备表1、配置类 二、使用selectPage1、Service2、结果 三、使用2种分页查询的写法1、xml2、Mapper3、第一种写法4、第一种结果5、第二种写法6、第二种结果...
    99+
    2023-08-20
    mybatis java 开发语言
  • mybatis-plus多表分页查询最佳实现(简单)
    1.简介 在Mybatis Plus 中,虽然IService 接口帮我们定义了很多常用的方法,但这些都是 T 对象有用,如果涉及到 多表的查询,还是需要自定义Vo 对象和自己编写sql 语句,Mybatis Plus提供了一个Page 对...
    99+
    2023-08-23
    mybatis java mysql
  • Mybatis实现联表查询并且分页功能
    今天同学突然问我这个怎么搞。 然后自己搞了一下发现这个玩意有坑。。就记录一下 0. 表结构 person表 cat表 一个person有多个cat 实体类就这么写 1. 实体类 ...
    99+
    2024-04-02
  • MyBatis-Plus 分页查询的实现示例
    方法: 使用selectPage()方法,第一个参数是传入分页方法(传入当前页和当前显示多少条数据),第二个参数是传入查询条件(如果查询全部的话,可以传null)。 前提: 表中的...
    99+
    2024-04-02
  • mybatis-plus分页查询的3种方法
    今天小编给大家分享的是mybatis-plus分页查询的3种方法,相信很多人都不太了解,为了让大家更加了解,所以给大家总结了以下内容,一起往下看吧。一定会有所收获的哦。一、前期准备表CREATE TABLE `schoo...
    99+
    2023-08-03
  • Mybatis-plus-join连表查询
    目录 一、数据库DDL 二、JAVA代码 三、pom依赖和配置文件               最近发现一个好玩的框架,我们知道mybatis-plus在连表查询上是不行的,如果需要连表查询,那么我们就得乖乖的去写xml文件了,但是今天发现...
    99+
    2023-08-31
    mybatis java mysql
  • MyBatis-Plus实现2种分页方法(QueryWrapper查询分页和SQL查询分页)
    目录 1 MyBatisPlusConfig2 UserPagination3 Mapper3.1 UserMapper.java3.2 UserMap...
    99+
    2024-04-02
  • MyBatis-Plus实现多表联查
    MyBatis-Plus多表联查写法 前言一、引依赖二、使用方法三、(实战)多表查询参数说明 四、(实战)多表分页查询 前言 收获大佬封装的一个jar包,可以支持MyBatis-...
    99+
    2023-09-03
    mybatis java sql
  • MyBatis Plus多表联查方法
    MyBatis Plus是一款针对MyBatis框架的增强工具, 它提供了很多方便的方法来实现多表联查. 你可以使用MyBatis Plus的selectPage方法来实现多表联查, 该方法接收一个QueryWrapper参数, 你可...
    99+
    2023-09-02
    mybatis java mysql maven spring
  • mybatis-plus多表关联查询功能的实现
    学习目标: mybatis-plus多表关联查询 学习内容: mybatis-plus多表关联查询 实体类部分代码 @Data @AllArgsConstructor @NoAr...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作