MybatisPlus多表查询及分页查询 2024/8/18 19:10

多表查询

  1. 实体类准备:在实体类中使用MyBatis-Plus的注解来映射数据库表和字段。比如,@TableName@TableField@TableId 注解用于标识实体类、字段以及主键。

  2. 构建查询条件:使用QueryWrapper类可以创建查询条件方法,并指定联合查询条件。在条件中使用表的别名来指定字段,比如user.age 指的是 user 表中的 age 字段。

  3. 执行查询:调用MyBatis-Plus提供的方法执行查询,比如selectList()selectPage()方法。

示例代码

// 多表查询示例
public List<UserVO> selectUserVOList() {
    QueryWrapper<User> queryWrapper = new QueryWrapper<>();
    queryWrapper.eq("user.age", 18)
                .like("user.username", "Jack")
                .orderByDesc("user.id");
    
    return userMapper.selectUserVOList(queryWrapper);
}

// 自定义 SQL 查询示例
@Select("SELECT u.id, u.username, a.address FROM user u INNER JOIN address a ON u.address_id = a.id WHERE u.age = #{age}")
List<UserAddressVO> selectUserAddressVOList(@Param("age") Integer age);

第一段段代码使用了 QueryWrapper 来构建查询条件。

  • queryWrapper.eq("user.age", 18) 表示筛选出 user 表中 age 字段值等于 18 的记录。

    • eq 是“等于”的条件设置方法。
  • queryWrapper.like("user.username", "Jack") 表示筛选出 user 表中 username 字段值类似于 “Jack” 的记录。

    • like 用于模糊匹配,这里会匹配包含 “Jack” 的用户名。
  • queryWrapper.orderByDesc("user.id") 表示按照 user 表中 id 字段的值降序排列查询结果。

    • orderByDesc 用于设置降序排序

例如,如果在查询用户数据时使用了这些条件,那么最终得到的结果将是年龄为 18 岁、用户名包含 “Jack” ,并且按照用户 id 从大到小排序的数据。

第二段段代码是一个在 MyBatis-Plus 中的自定义 SQL 查询的示例。

  • @Select("SELECT u.id, u.username, a.address FROM user u INNER JOIN address a ON u.address_id = a.id WHERE u.age = #{age}"):这是一个 @Select 注解,用于定义一个自定义的 SQL 查询语句。它表示从 user 表(表别名 u )和 address 表(表别名 a )进行内连接(INNER JOIN ),连接条件是 u.address_id = a.id ,并且筛选出 u.age 等于传入参数 age 的记录。#{age} 是一个占位符,用于接收实际传入的参数值。

  • List<UserAddressVO> selectUserAddressVOList(@Param("age") Integer age):这定义了一个方法,返回类型是一个 List ,其中元素类型是 UserAddressVO 。方法名为 selectUserAddressVOList ,并且通过 @Param("age") 注解将传入的参数 age 与 SQL 语句中的占位符 #{age} 进行关联。

例如,如果传入的 age 值为 20 ,那么这个查询就会返回年龄为 20 岁的用户的 idusername 以及对应的地址信息。

补充:

内连接(inner join)是SQL中最常见的连接类型之一,用于根据两个表之间的共同值来合并数据。内连接返回两个表中满足连接条件的行,即返回两个表中共同的行。
具体来说,内连接会根据连接条件(通常是两个表之间的共同字段)将两个表中符合条件的行进行匹配,并将匹配的结果作为输出。如果某行在一个表中有匹配,但在另一个表中没有匹配,那么这行数据将不会包含在内连接的结果中。
内连接通常使用INNER JOIN关键字来表示,语法形式如下:

SELECT 列名
FROM1
INNER JOIN2
ON1.共同字段 =2.共同字段;

在这个语句中,INNER JOIN表示进行内连接操作,ON关键字用于指定连接条件,即指定两个表之间用于匹配的共同字段。
内连接是SQL中最常用的连接类型之一,用于从多个表中检索相关数据,是数据查询和分析中非常重要的操作。

分页查询

  1. 准备分页对象:MyBatis-Plus提供了Page类,用于封装分页查询条件。你需要传入页码和每页查询数量作为参数。

  2. 构建分页查询条件:在查询条件中指定需要查询的条件,然后将分页对象和查询条件传递给selectPage()方法。

  3. 执行分页查询:调用selectPage()方法执行分页查询,它会返回一个IPage对象,其中包含了查询结果和分页信息。

示例代码

// 分页查询示例
public IPage<User> selectUserPage(Page<User> page) {
    QueryWrapper<User> queryWrapper = new QueryWrapper<>();
    queryWrapper.eq("age", 18);
    
    return userMapper.selectPage(page, queryWrapper);
}

// 自定义分页查询示例
public IPage<User> selectUserPage(Page<User> page, Integer age) {
    QueryWrapper<User> queryWrapper = new QueryWrapper<>();
    queryWrapper.eq("age", age);
    
    return userMapper.selectPage(page, queryWrapper);
}

第一段代码:分页查询示例

public IPage<User> selectUserPage(Page<User> page) {
    QueryWrapper<User> queryWrapper = new QueryWrapper<>();
    queryWrapper.eq("age", 18);
    
    return userMapper.selectPage(page, queryWrapper);
}
  • public IPage<User> selectUserPage(Page<User> page):这定义了一个公共方法,返回类型为 IPage<User>,表示分页查询的结果。方法名为 selectUserPage,并接收一个 Page<User> 类型的参数 page,用于设置分页的相关信息(如当前页码、每页条数等)。
  • QueryWrapper<User> queryWrapper = new QueryWrapper<>();:创建了一个用于构建查询条件的 QueryWrapper 对象。
  • queryWrapper.eq("age", 18);:使用 eq 方法设置查询条件,即筛选出年龄(age)等于 18 的用户记录。
  • return userMapper.selectPage(page, queryWrapper);:调用 userMapper 中的 selectPage 方法进行分页查询。将之前创建的分页对象 page 和包含查询条件的 queryWrapper 作为参数传入,最终返回分页查询的结果。

第二段代码:自定义分页查询示例

public IPage<User> selectUserPage(Page<User> page, Integer age) {
    QueryWrapper<User> queryWrapper = new QueryWrapper<>();
    queryWrapper.eq("age", age);
    
    return userMapper.selectPage(page, queryWrapper);
}

这段代码与第一段类似,但增加了一个参数 age 用于自定义年龄条件。

  • public IPage<User> selectUserPage(Page<User> page, Integer age):方法接收两个参数,除了分页对象 page ,还有一个整数类型的 age 参数,用于指定具体的年龄条件。
  • queryWrapper.eq("age", age);:这里将传入的 age 参数值作为年龄的筛选条件。
  • 同样通过 userMapper.selectPage(page, queryWrapper) 进行分页查询并返回结果。

例如,如果在第一段代码中,假设每页显示 10 条数据,当前是第 2 页,那么它会返回年龄为 18 岁的用户数据,并且按照每页 10 条,第 2 页的规则进行分页。

在第二段代码中,如果传入的 age 为 25 ,其他条件相同,那么会返回年龄为 25 岁的用户数据的分页结果。

补充:

在上述代码中,Page<User> page 是一个用于分页操作的对象,它具有以下几个重要的属性和功能:

  1. current:表示当前要获取的页码。页码从 1 开始计数。例如,如果 current 的值为 2 ,则表示要获取的是第 2 页的数据。
  2. size:指定每页显示的记录数量。例如,如果 size 的值为 10 ,则每页将返回 10 条记录。
  3. 除了设置这两个属性来控制分页的页码和每页记录数,Page 对象还可以用于获取一些与分页相关的其他信息,比如:
- 总记录数:通过调用相关方法可以获取整个查询结果集的总记录数。

- 总页数:根据总记录数和每页记录数,可以计算出总的页数。

- 是否有上一页和下一页:可以判断当前页是否有前一页或后一页,以便在前端进行页面导航的显示控制。

假设我们有一个数据库表,其中总共有 50 条用户记录,并且设置 pagesize 为 10 :

  • 如果 current 为 1 ,则会获取第 1 页的 10 条记录(记录 1 - 10)。
  • 如果 current 为 3 ,则会获取第 3 页的 10 条记录(记录 21 - 30)。

这样,通过灵活设置 page 对象的 currentsize 属性,就可以实现对数据的分页获取和展示。

使用 Page 对象进行分页查询的完整代码示例

import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import org.junit.jupiter.api.Test;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;

import java.util.List;

@SpringBootTest
public class PageExampleTest {

    @Autowired
    private UserMapper userMapper;  // 假设您有一个 UserMapper 接口

    @Test
    public void testPageQuery() {
        // 创建 Page 对象,设置当前页码为 2,每页记录数为 5
        Page<User> page = new Page<>(2, 5);

        QueryWrapper<User> queryWrapper = new QueryWrapper<>();
        // 可以添加其他查询条件

        IPage<User> userIPage = userMapper.selectPage(page, queryWrapper);

/*在 MyBatis-Plus 中,`IPage` 是 MyBatis-Plus 自定义的用于表示分页结果的接口。通过使用 `IPage` ,可以方便地获取分页相关的信息,如总记录数、当前页数据、每页记录数、当前页码、总页数等。*/

        // 获取总记录数
        long total = userIPage.getTotal();

        // 获取当前页数据列表
        List<User> userList = userIPage.getRecords();

        // 获取当前页码
        int currentPage = userIPage.getCurrent();

        // 获取每页记录数
        int pageSize = userIPage.getSize();

        // 获取总页数
        int totalPages = userIPage.getPages();

        System.out.println("总记录数: " + total);
        System.out.println("当前页数据列表: " + userList);
        System.out.println("当前页码: " + currentPage);
        System.out.println("每页记录数: " + pageSize);
        System.out.println("总页数: " + totalPages);
    }
}
  • 9
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值