锋盈数科-知识库 Logo
首页
软件开发
计算机基础
Hello Halo
新手必读
关于本知识库
登录 →
锋盈数科-知识库 Logo
首页 软件开发 计算机基础 Hello Halo 新手必读 关于本知识库
登录
  1. 首页
  2. 软件开发
  3. JAVA
  4. MyBatis-plus-02

MyBatis-plus-02

0
  • JAVA
  • 发布于 2024-09-26
  • 6 次阅读
黄健
黄健

分页查询
分页查询是一种常见的数据库查询技术,用于在大量数据中检索特定范围的数据。该技术可以将数据划分为多个页面(或称为页),每页包含固定数量的数据条目。通过指定页码和每页数据条目的数量,可以有效地实现分页查询。
分页查询通常包括以下几个步骤:

  1. 指定每页数据条目的数量(通常为固定值)。
  2. 指定要检索的页码。
  3. 计算起始行数和结束行数,即确定要从数据库中检索的数据范围。
  4. 使用起始行数和结束行数作为条件执行数据库查询。
  5. 获取查询结果,并将其呈现给用户。
    例如,假设有一张名为"users"的用户表,包含100条用户记录。要查询第3页,每页显示10条记录,可以按以下步骤执行分页查询:
  6. 指定每页数据条目的数量为10。
  7. 指定要查询的页码为3。
  8. 计算起始行数和结束行数。对于第3页,起始行数为21(=(3-1)10+1),结束行数为30(=310)。
  9. 使用起始行数和结束行数作为条件执行数据库查询语句,例如"SELECT * FROM users LIMIT 21, 10”。
  10. 获取查询结果,即第3页的用户记录。
    分页查询在Web应用程序中非常常见,因为它允许用户分批加载大量数据,提高性能和用户体验。

步骤:
1.启动类中导入分页插件

//将mybatis-plus插件加入ioc容器
    @Bean
    public MybatisPlusInterceptor plusInterceptor(){

        MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor();
        mybatisPlusInterceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
        return mybatisPlusInterceptor;
    }

2.使用分页查询

    @Test
    public void testPage(){

        Page<User> page=new Page<>(1,3); //查询第一页第三个参数
        userMapper.selectPage(page,null);
        long current = page.getCurrent();   //页码
        long size = page.getSize();         //页容量
        List<User> records = page.getRecords(); //当前页的数据
        long total = page.getTotal();       //总条数
    }

自定义的mapper方法使用分页

public interface UserMapper extends BaseMapper<User> {

    //自定义根据年龄查询并分页      age>xx
    IPage<User> queryByAge(IPage<User> page,@Param("age") Integer age);
}


    //自定义分页
    @Test
    public void testMyPage(){

        Page<User> page=new Page<>(1,3);
        userMapper.queryByAge(page,1);
        long current = page.getCurrent();   //页码
        System.out.println("current = " + current);
        long size = page.getSize();         //页容量
        System.out.println("size = " + size);
        List<User> records = page.getRecords(); //当前页的数据
        System.out.println("records = " + records);
        long total = page.getTotal();       //总条数
        System.out.println("total = " + total);
    }


<mapper namespace="com.dc.mapper.UserMapper">
    <select id="queryByAge" resultType="user">
        select * from user where age>#{
   age}
    </select>
</mapper>

type-aliases-package: com.dc.pojo       #开启别名

条件构造器
使用MyBatis-Plus的条件构造器,可以构建灵活、高效的查询条件,而不需要手动编写复杂的 SQL 语句。它提供了许多方法来支持各种条件操作符,并且可以通过链式调用来组合多个条件。这样可以简化查询的编写过程,并提高开发效率。

基于QueryWrapper 组装条件:

@Test
    public void test_01(){

        //查询用户名包含a,年龄在20到30之间,并且邮箱不为null的用户信息
        QueryWrapper<User> queryWrapper=new QueryWrapper<>();
        queryWrapper.like("name","a");
        queryWrapper.between("age",20,30);
        queryWrapper.isNotNull("email");
        /*链式调用
        * queryWrapper.like("name","a").between("age",20,30).isNotNull("email");
        * */
        List<User> users=userMapper.selectList(queryWrapper);
        System.out.println("users = " + users);
    }

默认and       queryWrapper.like("name","a").between("age",20,30)
    or      queryWrapper.like("name","a").or().between("age",20,30)

queryMapper.select("name","age");   //指定查询的列


//动态语句查询    name不为空时才作为查询条件
       //动态语句查询    name不为空时才作为查询条件
        String name="xxxx";
        queryMapper.eq(StringUtils.isNotBlank(name),"name",name);

基于 UpdateWrapper组装条件:
使用queryWrapper + 实体类形式可以实现修改,但是无法将列值修改为null值
使用updateWrapper可以随意设置列的值

基于LambdaQueryWrapper组装条件 基于LambdaUpdateWrapper组装条件: 【推荐】
相比于 QueryWrapper,LambdaQueryWrapper 使用了实体类的属性引用(例如 User::getName、User::getAge),而不是字符串来表示字段名,这提高了代码的可读性和可维护性。

QueryWrapper<User> queryWrapper=new QueryWrapper<>();
        queryWrapper.like("name","a").between("age",20,30)
                .isNotNull("email");

LambdaQueryWrapper<User> userLambdaQueryWrapper=new LambdaQueryWrapper<>();
userLambdaQueryWrapper.like(User::getName,"a")
            .between(User::getAge,20,30)
            .isNotNull(User::getEmail);

原文链接: https://blog.csdn.net/qq_53568730/article/details/135677707

标签: #JAVA 991 #mybatis-plus 7
相关文章

Spring 实现 3 种异步接口 2024-10-18 09:07

大家好,我是苏三~ 如何处理比较耗时的接口? 这题我熟,直接上异步接口,使用 Callable、WebAsyncTask 和 DeferredResult、CompletableFuture等均可实现。 但这些方法有局限性,处理结果仅返回单个值。在某些场景下,如果需要接口异步处理的同时,还持续不断地

重学SpringBoot3-集成Redis(五)之布隆过滤器 2024-10-08 11:24

更多SpringBoot3内容请关注我的专栏:《SpringBoot3》 期待您的点赞👍收藏⭐评论✍ 重学SpringBoot3-集成Redis(五)之布隆过滤器 1. 什么是布隆过滤器? * 基本概念 适用场景 2. 使用 Redis 实现布隆过滤器 * 项目依赖 Redis 配置

SpringBoot整合异步任务执行 2024-10-08 11:24

同步任务: 同步任务是在单线程中按顺序执行,每次只有一个任务在执行,不会引发线程安全和数据一致性等 并发问题 同步任务需要等待任务执行完成后才能执行下一个任务,无法同时处理多个任务,响应慢,影响用 户体验 异步任务: 异步任务是在多线程中同时执行,多个任务可以并发执行,同时处理多个请求,响应快,资源

springboot kafka多数据源,通过配置动态加载发送者和消费者 2024-10-08 11:24

前言 最近做项目,需要支持kafka多数据源,实际上我们也可以通过代码固定写死多套kafka集群逻辑,但是如果需要不修改代码扩展呢,因为kafka本身不处理额外逻辑,只是起到削峰,和数据的传递,那么就需要对架构做一定的设计了。 准备test kafka本身非常容易上手,如果我们需要单元测试,引入ja

SpringBoot 集成 Redis 2024-10-08 11:24

一:SpringBoot 集成 Redis ①Redis是一个 NoSQL(not only)数据库, 常作用缓存 Cache 使用。 ②Redis是一个中间件、是一个独立的服务器;常用的数据类型: string , hash ,set ,zset , list ③通过Redis客户端可以使用多种语

SpringBoot整合QQ邮箱 2024-10-08 11:24

SpringBoot可以通过导入依赖的方式集成多种技术,这当然少不了我们常用的邮箱,现在本章演示SpringBoot整合QQ邮箱发送邮件…. 下面按步骤进行: 1.获取QQ邮箱授权码 1.1 登录QQ邮箱 1.2 开启SMTP服务 找到下图中的SMTP服务区域,如果当前账号未开启的话自己手动开启。

目录

IT 外包服务商

  • 意见投递
  • zyf6619

软件开发应用

主菜单

  • 首页
  • 软件开发
  • 计算机基础
  • Hello Halo
  • 新手必读
  • 关于本知识库
Copyright © 2024 your company All Rights Reserved. Powered by Halo.