java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > MybatisPlus多表查询

MybatisPlus多表查询及分页查询完整代码

作者:华农第一蒟蒻

这篇文章主要介绍了MybatisPlus多表查询及分页查询完整代码,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧

多表查询

示例代码

// 多表查询示例
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);
// 多表查询示例
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 来构建查询条件。

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

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

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

补充:

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

SELECT 列名
FROM 表1
INNER JOIN 表2
ON 表1.共同字段 = 表2.共同字段;

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

分页查询

示例代码

// 分页查询示例
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, Integer age) {
    QueryWrapper<User> queryWrapper = new QueryWrapper<>();
    queryWrapper.eq("age", age);
    return userMapper.selectPage(page, queryWrapper);
}

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

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

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

补充:

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

- 总记录数:通过调用相关方法可以获取整个查询结果集的总记录数。
- 总页数:根据总记录数和每页记录数,可以计算出总的页数。
- 是否有上一页和下一页:可以判断当前页是否有前一页或后一页,以便在前端进行页面导航的显示控制。

这样,通过灵活设置 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);
    }
}

到此这篇关于MybatisPlus多表查询及分页查询的文章就介绍到这了,更多相关MybatisPlus多表查询内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文