MyBatis-Plus之select、delete用法及说明

 更新时间:2026年04月25日 11:53:59   作者:今日相乐,皆当喜欢  
文章主要讲解了Mybatis-Plus中的查询和删除操作,查询操作包括根据ID、批量和使用map进行条件查询,以及内置分页插件的使用,删除操作则包括物理删除和逻辑删除,其中逻辑删除需要在数据库和实体类中进行相关配置

一、Mybatis-Plus之查询操作

1、查询操作常用API

根据ID查询测试代码如下:

//测试根据ID查询
@Test
public void testSelectById(){
	User user = userMapper.selectById(2L);
	System.out.println(user);
}

测试结果如下:

批量查询测试代码如下:

//测试批量查询
@Test
public void testSelectByBatchIds(){
	List<User> users = userMapper.selectBatchIds(Arrays.asList(1, 2, 3));
	users.forEach(System.out::println);
}

测试结果如下:

使用map进行条件查询测试代码如下:

//按条件查询之使用map操作
@Test
public void testSelectByMap(){
	Map map = new HashMap();
	map.put("name","哈利油");
	map.put("age",18);
 
	List list = userMapper.selectByMap(map);
	list.forEach(System.out::println);
}

测试结果如下:

2、分页查询

分页在项目里使用得十分多,平时一般是使用pageHelpr插件进行分页,还可以使用原始的limit进行分页;MP其实内置了分页插件,使用步骤如下:

2.1、在配置类里注册分页插件

//注册分页插件
@Bean
public PaginationInterceptor paginationInterceptor(){
	return new PaginationInterceptor();
}

2.2、直接使用MP内置的Page对象进行分页,测试代码如下

@Test
public void testPage(){
	//参数1:当前页,参数2:页面大小
	Page<User> page = new Page<>(1,5);
	//用于排序
	page.setDesc("id");
	IPage<User> userIPage = userMapper.selectPage(page, null);
 
	userIPage.getRecords().forEach(System.out::println);
	System.out.println(userIPage.getTotal());
}

测试结果如下:

二、Mybatis-Plus之删除操作

1、物理删除操作常用API

根据ID删除测试代码如下:

//测试删除
@Test
public void testDeleteById(){
	userMapper.deleteById(1L);
}

测试结果如下:

根据ID批量删除测试代码如下:

//通过id批量删除
@Test
public void testDeleteBatchId(){
	userMapper.deleteBatchIds(Arrays.asList(2L,3L));
}

测试结果如下:

使用map进行条件删除测试代码如下:

@Test
public void testDeleteMap(){
	Map map = new HashMap();
	map.put("name","哈利油");
	userMapper.deleteByMap(map);
}

测试结果如下:

2、逻辑删除

在工作中有时需要使用到逻辑删除,逻辑删除即数据在数据库里没有被移除,而是通过一个变量来让它失效;一般管理员可以查看被逻辑删除的数据,这样可防止数据的丢失,类似于回收站功能

MP逻辑删除使用步骤如下:

2.1、在数据库里增加deleted字段

2.2、在实体类对应的属性上加上@TableLogic注解

2.3、在配置类里注册逻辑删除组件

//注册逻辑删除组件
@Bean
public ISqlInjector sqlInjector(){
	return new LogicSqlInjector();
}

2.4、在application.properties文件里配置

已删除跟未删除用什么来表示

mybatis-plus.global-config.db-config.logic-delete-value=1
mybatis-plus.global-config.db-config.logic-not-delete-value=0

2.5、测试逻辑删除

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • JAVA像SQL一样对List对象集合进行排序

    JAVA像SQL一样对List对象集合进行排序

    这篇文章主要介绍了JAVA像SQL一样对List对象集合进行排序的实现方法,文中讲解非常细致,代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-07-07
  • 浅谈MyBatis-plus入门使用

    浅谈MyBatis-plus入门使用

    这几天本人了解到了MyBatis-plus,一个 Mybatis 增强工具包.经过一番研究,发现这玩意真的好用,不用写任何 xml ,内置通用的 Mapper,而且完全是面向对象编程,文档给的示例代码,跟之前用过的 sequelize (Node.js 的 ORM)非常像,因此本人也尝试了一把, 需要的朋友可以参考下
    2021-05-05
  • Kafka中使用Avro序列化和反序列化详解

    Kafka中使用Avro序列化和反序列化详解

    这篇文章主要介绍了Kafka中使用Avro序列化和反序列化详解,由于Kafka中的数据都是字节数组,在将消息发送到Kafka之前需要先将数据序列化为字节数组, 序列化器的作用就是用于序列化要发送的消息的,需要的朋友可以参考下
    2023-12-12
  • Java基于虹软实现人脸识别、人脸比对、活性检测等

    Java基于虹软实现人脸识别、人脸比对、活性检测等

    本文主要介绍了Java基于虹软实现人脸识别、人脸比对、活性检测等,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • Spring Framework路径遍历漏洞(CVE-2024-38819) 的最新解决方案

    Spring Framework路径遍历漏洞(CVE-2024-38819) 的最新解决方案

    本文介绍SpringFramework 6.1.14+升级方案以修复CVE-2024-38819漏洞,需检查依赖、调整配置、验证兼容性(如JDK17)、测试核心功能及准备回滚计划,确保升级后系统稳定,感兴趣的朋友跟随小编一起看看吧
    2025-08-08
  • Java实现自动把报表插入到word文档中

    Java实现自动把报表插入到word文档中

    在很多业务场景中需要在 word 文档中嵌入报表,这篇文章主要为大家介绍了如何使用Java实现自动把报表插入到word文档中,需要的可以参考下
    2024-12-12
  • java学习笔记之DBUtils工具包详解

    java学习笔记之DBUtils工具包详解

    下面小编就为大家分享一篇java学习笔记之DBUtils工具包详解,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-01-01
  • 使用Runtime 调用Process.waitfor导致的阻塞问题

    使用Runtime 调用Process.waitfor导致的阻塞问题

    这篇文章主要介绍了使用Runtime 调用Process.waitfor导致的阻塞问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-12-12
  • springboot如何使用vue打包过的页面资源

    springboot如何使用vue打包过的页面资源

    这篇文章主要介绍了springboot如何使用vue打包过的页面资源,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-12-12
  • Mybatis获取自增主键的两种实现原理小结

    Mybatis获取自增主键的两种实现原理小结

    MyBatis通过useGeneratedKeys和两种方式适配不同数据库的自增主键生成,利用JDBC接口和KeyGenerator实现高效获取与回写,下面就来介绍一下
    2025-08-08

最新评论