springboot和vue:七、mybatis/mybatisplus多表查询+分页查询

这篇具有很好参考价值的文章主要介绍了springboot和vue:七、mybatis/mybatisplus多表查询+分页查询。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

mybatisplus实际上只对单表查询做了增强(速度会更快),从传统的手写sql语句,自己做映射,变为封装好的QueryWrapper。
本篇文章的内容是有两张表,分别是用户表和订单表,在不直接在数据库做表连接的情况下,通过后台代码完成①查询订单的同时查到该订单所属的用户,②查询用户的同时查到该用户的订单列表的功能。

Mybatis版本

准备表环境

t_user

springboot和vue:七、mybatis/mybatisplus多表查询+分页查询,快速入门springboot和vue,spring boot,mybatis,后端,java,springboot

springboot和vue:七、mybatis/mybatisplus多表查询+分页查询,快速入门springboot和vue,spring boot,mybatis,后端,java,springboot


### t_order

springboot和vue:七、mybatis/mybatisplus多表查询+分页查询,快速入门springboot和vue,spring boot,mybatis,后端,java,springboot


springboot和vue:七、mybatis/mybatisplus多表查询+分页查询,快速入门springboot和vue,spring boot,mybatis,后端,java,springboot

编写实体类

Order类

@TableName("t_order")
public class Order {
    @TableId(type = IdType.AUTO)
    private int id;
    private String order_time;
    private String total;
    private int uid;
    @TableField(exist = false)
    private User user;
  • @TableName表示数据库表名的映射。其实加上与不加都无所谓。因为我们先用的是mybatis,最终会自己写一个方法去映射。
  • @TableId(type = IdType.AUTO)表示该注解下面的字段在数据库是自增的。
  • @TabelField(exist = false)表示该注解下面的字段在数据库中实际是不存在的,mybatis不需要去数据库中映射,我们自己会编写映射方法。

最后记得在类里面自动生成getter和setter还有toString方法。

User类

@TableName("t_user")
public class User {
   @TableId(type = IdType.AUTO)
   private int id;
   private String username;
   private String password;
   private String birthday;
   //描述用户的所有订单
   @TableField(exist = false)
   private List<Order>  orders;

@TableName同上,加与不加都无所谓。最后记得在类里面自动生成getter和setter还有toString方法。

编写mapper方法

UserMapper

@Mapper
public interface UserMapper extends BaseMapper<User> {

    @Update("insert into t_user values (#{id},#{username},#{password},#{birthday})")
    public int insert(User user);

    //查询用户及其所有的订单
    @Select("select * from t_user")
    @Results(
            {
                    @Result(column = "id",property = "id"),
                    @Result(column = "username",property = "username"),
                    @Result(column = "password",property = "password"),
                    @Result(column = "birthday",property = "birthday"),
                    @Result(column = "id",property = "orders",javaType = List.class,
                    many = @Many(select = "com.example.mybatisplusdemo.mapper.OrderMapper.selectByUid")
                    )
            }
    )
    List<User> selectAllUserAndOrders();
}
  • @Result的column代表数据库里的列名,property代表代码里的数据结构。即从数据库里查到的数据映射到代码里的哪个参数。
  • 因为一个用户可能有多个订单,所以最后一个@Result里面写的是的many=@Many。
  • 最后一个@Result表明的意思是mybatis/mybatisplus允许在mapper方法内部继续调用一个mapper方法,把column里查到的数值传给mapper方法,最终后者返回的结果才是真正传给property的值。
  • 注意调用的mapper方法需要写全类名(上篇文章提到过如何快速复制)再加方法名。

OrderMapper

@Select("select * from t_order where uid = #{uid}")
List<Order> selectByUid(int uid);
    
 @Select("select * from t_order")
    @Results(
            {
                    @Result(column = "id",property = "id"),
                    @Result(column = "ordertime",property = "ordertime"),
                    @Result(column = "total",property = "total"),
                    @Result(column = "uid",property = "user",javaType = User.class,
                            one = @One(select = "com.example.mybatisplusdemo.mapper.UserMapper.selectById")
                    )
            }
    )
    List<Order> selectAllOrderAndUser();

注意到是one = @One,因为一个订单只对应着一个用户。

编写controller方法

OrderController

@RestController
@CrossOrigin
public class OrderController {
    @Autowired
    private OrderMapper orderMapper;

    @GetMapping("/order/findAll")
    public List findAll()
    {
        List orders = orderMapper.selectAllOrderAndUser();
        return  orders;
    }
}

UserController

@RestController
@CrossOrigin
public class UserController {

    @Autowired
    private UserMapper userMapper;

    @GetMapping("/user")
    public List query(){
        List<User> list = userMapper.selectList(null);
        System.out.println(list);
        return list;
    }

    @GetMapping("/user/findAll")
    public List<User> find(){ return userMapper.selectAllUserAndOrders();}
}

测试

springboot和vue:七、mybatis/mybatisplus多表查询+分页查询,快速入门springboot和vue,spring boot,mybatis,后端,java,springboot

springboot和vue:七、mybatis/mybatisplus多表查询+分页查询,快速入门springboot和vue,spring boot,mybatis,后端,java,springboot

MybatisPlus版本做条件查询

mybatisplus提供了封装好的QueryWrapper类,让我们做条件查询或者更新查询。
注意如果想要使用mybatisplus,要把原来实体类里的@TableField加上

编写controller类

UserMapper

@RestController
public class UserController {
    @Autowired
    private UserMapper userMapper;

    @GetMapping("/user/find")
    public List<User> query() {
        QueryWrapper<User> queryWrapper = new QueryWrapper<>();
        queryWrapper.eq("username","zhangsan");
        // 筛选出用户名为张三的用户。
        return userMapper.selectList(queryWrapper);
    }
}

测试

springboot和vue:七、mybatis/mybatisplus多表查询+分页查询,快速入门springboot和vue,spring boot,mybatis,后端,java,springboot

MybatisPlus版本做分页查询

编写配置类

新建一个软件包config,编写一个配置类

@Configuration
public class MyBatisPlusConfig {
    @Bean
    public MybatisPlusInterceptor paginationInterceptor(){
        MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor(); // 定义一个拦截器
        PaginationInnerInterceptor paginationInnerInterceptor = new PaginationInnerInterceptor(DbType.MYSQL); //告诉它数据库类型
        interceptor.addInnerInterceptor(paginationInnerInterceptor);// 拦截器注册
        return interceptor;
    }
}

在controller里面添加方法

在UserController中添加分页查询方法

@GetMapping("user/findByPage")
    public IPage findByPage(){
        Page<User> page = new Page<>(0,2); // 设置起始值和每页条数
        IPage iPage = userMapper.selectPage(page,null); // 返回结果集,这里如果想额外增加附属条件
        //可以写在第二个参数queryWrapper中
        return iPage;
    }

测试

springboot和vue:七、mybatis/mybatisplus多表查询+分页查询,快速入门springboot和vue,spring boot,mybatis,后端,java,springboot文章来源地址https://www.toymoban.com/news/detail-729512.html

到了这里,关于springboot和vue:七、mybatis/mybatisplus多表查询+分页查询的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MyBatis-Plus分页查询(快速上手运用)

    Mybatis-Plus知识点[MyBatis+MyBatis-Plus的基础运用]_心态还需努力呀的博客-CSDN博客   Mybatis-Plus+SpringBoot结合运用_心态还需努力呀的博客-CSDN博客 MyBaits-Plus中@TableField和@TableId用法_心态还需努力呀的博客-CSDN博客 MyBatis-Plus中的更新操作(通过id更新和条件更新)_心态还需努力呀的博

    2024年02月16日
    浏览(40)
  • java springboot整合MyBatis实现分页查询以及带条件的分页查询

    之前的文章 java springboot整合MyBatis做数据库查询操作操作了springboot整合MyBatis,然后简单做了个按id查询的操作 那么 我们按上文搭建起的环境继续 我们直接在staffDao接口中声明一个分页函数 这里 我们直接在 sql语句中写limit 分页逻辑 参数是方法接收的 这个函数接收两个参数

    2024年02月10日
    浏览(35)
  • springboot-mybatis的分页查询的接口

    直接查询所有数据即可,剩下的交给分页器 PageHelper.startPage(page, pageSize) ; 是 MyBatis 的一个分页插件(PageHelper)提供的方法调用,用于在数据库查询中实现分页功能。这个方法的作用是告诉 PageHelper 开始对接下来的查询进行分页处理。 具体来说,这个方法做了以下几件事情:

    2024年02月14日
    浏览(21)
  • MybatisPlus多表连表查询

    最近发现一个好玩的框架,我们知道mybatis-plus在连表查询上是不行的,如果需要连表查询,那么我们就得乖乖的去写xml文件了,但是今天发现一个新的框架 mybatis-plus-join。它既包含了mybatis-plus的所有优点,然后还支持连表查询,还支持对多,对一的查询 mybatis-plus-join是mybati

    2024年02月13日
    浏览(41)
  • 【SpringBoot】MyBatis与MyBatis-Plus分页查询 & github中的PageHelper

            笔者写这篇博客是因为近期遇到的关于两者之间的分页代码差距,其实之前也遇见过但是没有去整理这篇博客,但由于还是被困扰了小一会儿时间,所以还是需要 加深记忆 。其实会看前后端传参解决这个问题很快、不麻烦。关于这两个框架的分页代码问题主要就

    2024年02月03日
    浏览(40)
  • SpringBoot整合mybatis-plus实现分页查询(建议收藏)

    一、前言         最近学习了SpringBoot分页查询的两种写法,一种是手动实现,另一种是使用框架实现。现在我将具体的实现流程分享一下。 二、手动实现分页查询         先复习一下,SQL中的limit,下面一行sql语句的意思是从第二个数据开始查,查询出两条数据

    2024年01月16日
    浏览(58)
  • tk-mybatis使用介绍,springboot整合tk-mybatis、PageHelper实现分页查询

    Mybatis-Plus极大简化了我们的开发,作为mybatis的增强版,Mybatis-Plus确实帮我们减少了很多SQL语句的编写,通过其提供的API,可以方便地完成增删查改操作。但是,其实除了Mybatis-Plus以外,还有一个技术tk-mybatis可以达到同样的效果,只不过随着MP的兴起,tk-mybatis已经被渐渐淡忘

    2024年02月12日
    浏览(26)
  • SpringBoot+Mybatis-Plus+Thymeleaf+Bootstrap分页查询(前后端完整版开源学习)图书管理系统

    Mybatis-Plus | Spring Boot+Mybatis-Plus+Thymeleaf+Bootstrap分页页查询(前后端都有) 主要参考了这篇博客。 运行截图 3.9.1 mybatis-plus 插入时间和更新时间字段自动填充工具 3.9.2 分页插件工具

    2023年04月11日
    浏览(34)
  • Mybatis——多表查询

    目录 一、简介 二、业务环境的准备 2.1、准备工作: 2.2、SQL 三、一对一和一对多 Sql语句: POJO  OrderMapper OrderMapper.xml  Test测试类 运行结果 MyBatis 是一个优秀的持久层框架,它提供了强大的支持来执行数据库操作,包括多表查询。多表查询是指从多个数据库表中检索数据的过

    2024年02月02日
    浏览(39)
  • MyBatis多表查询

    目录 1. 多表关系回顾 2. 一对一查询 2.1 一对一多表查询方式一:基于标签进行手动结果映射封装  2.2 一对一多表查询方式二 - 通过标签来封装属性中所关联的对象 3. 一对多查询 4. 多对多查询 在项目开发当中一对一关系的表不常见,因为一对一关系的两张表通常会合并为一

    2024年02月10日
    浏览(24)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包