MyBatisPlus之增删改查

系列文章目录

提示:这里可以添加系列文章的所有文章的目录,目录需要自己手动添加
MyBatisPlus之增删改查


提示:写完文章后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 系列文章目录
  • 前言
  • 一、什么是MybatisPlus?
  • 二、SpringBoot集成MyBatisPlus
  • 三、MybatisPlus增删改查
    • 新增
    • 修改
    • 删除
      • 根据id删除
      • 批量删除
      • 根据条件删除
    • 查询
      • 根据id查询
      • 根据id批量查询
      • 根据字段条件查询
      • 条件构造器查询
        • 什么是条件构造器
        • 条件构造器参数
        • 条件构造器用法
      • 分页查询
  • 总结


前言

提示:这里可以添加本文要记录的大概内容:

在当今的软件开发领域,Java 一直占据着重要的地位。而在 Java 数据库操作方面,MyBatis-Plus 以其简洁、高效、易用的特点,成为了许多开发者的首选。
MyBatis-Plus 是一个基于 MyBatis 的增强工具,它在 MyBatis 的基础上进行了扩展和优化,提供了更加方便快捷的数据库操作方式。使用 MyBatis-Plus,我们可以通过注解和配置文件来轻松地实现数据库的增删改查操作,极大地提高了开发效率。
在本博客中,我们将详细介绍 MyBatis-Plus 的增删改查功能,并通过实际的代码示例来演示如何使用这些功能。我们将从基础知识开始,逐步深入探讨 MyBatis-Plus 的高级特性。无论你是刚刚接触 MyBatis-Plus,还是已经有一定经验的开发者,都能从中受益。
通过阅读本博客,你将了解到如何利用 MyBatis-Plus 进行高效的数据库操作,以及如何优化你的代码以获得更好的性能。让我们一起开启 MyBatis-Plus 之旅吧!


提示:以下是本篇文章正文内容,下面案例可供参考

一、什么是MybatisPlus?

MyBatis-Plus 是一个基于 MyBatis 框架的增强工具,它提供了一系列额外的功能和特性,使数据库操作更加简单和高效。MyBatis-Plus 的主要特点和优势包括:

  • 简化 SQL 编写:MyBatis-Plus 提供了丰富的注解和内置方法,极大地简化了 SQL 查询语句的编写。你可以通过注解或方法调用的方式来定义查询条件、分页、排序等,而无需手动编写复杂的 SQL 语句。
  • 自动生成代码:MyBatis-Plus 可以根据数据库表结构自动生成实体类、Mapper 接口、Service 类等相关代码,减少了手动编写代码的工作量。
  • 懒人式 CRUD 操作:MyBatis-Plus 提供了懒人式的 CRUD(增删改查)操作方法,你可以通过简单的调用方法来实现对数据库的增删改查操作,无需编写复杂的 SQL 语句和映射文件。
  • 分页和排序功能:MyBatis-Plus 内置了强大的分页和排序功能,你可以通过简单的设置来实现分页和排序,无需手动编写 SQL 语句。
  • 性能优化:MyBatis-Plus 对查询语句进行了优化,支持缓存、动态 SQL、延迟加载等技术,提高了数据库操作的性能。
  • 灵活的插件机制:MyBatis-Plus 支持插件扩展,你可以通过编写插件来实现自定义功能,如拦截器、分页插件等。

二、SpringBoot集成MyBatisPlus

1.创建SpringBoot项目,添加MyBatisPlus起步依赖

<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter</artifactId>
</dependency>
<dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-test</artifactId><scope>test</scope>
</dependency>
<!-- MyBatisPlus -->
<dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-boot-starter</artifactId><version>3.5.0</version>
</dependency>
<!-- mysql驱动 -->
<dependency><groupId>mysql</groupId><artifactId>mysql-connector-java</artifactId><version>8.0.26</version>
</dependency>
<!-- lombok -->
<dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><optional>true</optional>
</dependency>

2.在SpringBoot配置文件中配置数据源

# 数据源
spring:datasource:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql:///school?serverTimezone=UTCusername: rootpassword: root

3.编写实体类,大家根据需求编写
4.编写Mapper接口,继承BaseMapper

public interface StudentMapper extends BaseMapper<Student> {
}

5.在 SpringBoot启动类中添加 @MapperScan 注解,扫描Mapper文件夹

@SpringBootApplication
@MapperScan("com.zhangsan.mpdemo2.mapper")
public class SpringbootMpApplication {public static void main(String[] args) {SpringApplication.run(SpringbootMpApplication.class, args);}
}

6.测试Mapper方法

@SpringBootTest
public class StudentMapperTest {@Autowiredprivate StudentMapper studentMapper;@Testpublic void testFindById(){Student student = studentMapper.selectById(1);System.out.println(student);}
}

三、MybatisPlus增删改查

新增

@Test
public void testAdd(){Student student = new Student(null,"zhangsan","zs@zs.com","m",20);studentMapper.insert(student);// MyBatisPlus插入成功后,可直接直接获取主键的值System.out.println(student.getId());
}

修改

@Test
public void testUpdate() {//创建实体类对象Student student = new Student();//设置需要更新的属性student.setName("zhangsan");//设置需要修改的数据idstudent.setId(1);//根据主键进行更新,没有设置的值则忽略studentMapper.updateById(student);
}

删除

根据id删除

// 根据id删除
@Test
public void testDeleteById(){studentMapper.deleteById(7);
}

批量删除

// 批量删除
@Test
public void testDeleteBatch(){ArrayList<Integer> ids = new ArrayList();ids.add(2);ids.add(3);studentMapper.deleteBatchIds(ids);
}

根据条件删除

// 根据字段条件删除
@Test
public void testDeleteMap(){Map<String,Object> map = new HashMap();// 键为数据库列名,而不是对象属性名map.put("sname","小王");map.put("gender","m");// 删除name为小王且gender为m的数据studentMapper.deleteByMap(map);

查询

根据id查询

// 根据id查询
@Test
public void testFindById() {Student student = studentMapper.selectById(1);System.out.println(student);
}

根据id批量查询

// 根据id批量查询
@Test
public void testFindBatch() {//创建主键集合List<Integer> ids = new ArrayList<>();ids.add(1);ids.add(2);ids.add(3);List<Student> students = studentMapper.selectBatchIds(ids);students.forEach(System.out::println);
}

根据字段条件查询

// 根据字段条件查询
@Test
public void testFindMap() {Map<String,Object> map = new HashMap<>();map.put("sname","zhangsan");map.put("gender","m");//查询name为baizhan,gender为m的数据List<Student> students = studentMapper.selectByMap(map);students.forEach(System.out::println);
}

条件构造器查询

什么是条件构造器

在MybatisPlus中,条件构造器是一个可以帮助我们使用面向对象的方式实现数据库操作的where条件的工具,它将条件封装成了一个Wrapper对象。在使用时,我们可以创建条件构造器对象,其中Wrapper和AbstractWrapper是两个抽象类,不能直接实例化,我们在使用时常用的具体实现是QueryWrapper和UpdateWrapper。
条件构造器在查询和修改数据库数据时非常有用。在写一些复杂查询时,我们可以创建一个测试类,并在其中注入需要的Mapper,然后创建一个条件构造器对象,并使用该对象设置查询条件。最后,可以调用Mapper的查询方法来获取结果。

条件构造器参数
查询方式说明
or或条件语句
and且条件语句
like模糊查询 like
notLike模糊查询 not Like
existsexists 条件语句
notExistsnot Exists 条件语句
isNullnull 值查询
isNotNullis Not Null 查询
inin 查询
notInnot in 查询
groupBy分组查询
orderBy排序查询
having分组后筛选
eq等于 =
ne不等于 <>
betweenbetween 条件语句
gt大于>
ge大于等于>=
lt小于<
le小于等于<=
条件构造器用法
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;public class Example {public static void main(String[] args) {// 创建一个测试类,并在其中注入需要的 MapperExample example = new Example();// 执行查询操作List<Integer> result = example.queryData();System.out.println(result);}public List<Integer> queryData() {// 创建一个条件构造器对象QueryWrapper<Integer> wrapper = new QueryWrapper<>();// 设置查询条件wrapper.lt("id", 10).gt("id", 5).like("name", "A%").eq("type", 1);// 调用 Mapper 的查询方法List<Integer> list = this.mapper.queryList(wrapper);return list;}
}

分页查询

1.在配置类或启动类配置分页插件

// 注册插件
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor = new MybatisPlusInterceptor();interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));return interceptor;
}

2.分页查询

// 分页查询
@Test
public void testFindPage() {//创建分页条件,从第0条数据开始,获取两条数据Page page = new Page(2,2);// 分页查询,第二个参数为QueryWrapper,用于添加查询条件IPage<Student> iPage = studentMapper.selectPage(page, null);// 打印分页数据System.out.println("结果集:"+iPage.getRecords());System.out.println("总页数:"+iPage.getPages());System.out.println("总条数:"+iPage.getTotal());System.out.println("当前页:"+iPage.getCurrent());System.out.println("每页条数:"+iPage.getSize());
}

总结

提示:这里对文章进行总结:

MybatisPlus是一个支持自动映射和简化数据库操作的Mybatis增强工具,提供了丰富的注解和扩展功能,用于简化数据库的增删改查操作。以下是MybatisPlus的增删改查总结:

  • 增:使用Mapper接口的相应方法,如insert(),传入实体对象作为参数,即可完成数据的新增。
  • 删:使用Mapper接口的相应方法,如delete(),传入实体对象作为参数,即可完成数据的删除。
  • 改:使用Mapper接口的相应方法,如update(),传入实体对象作为参数,并指定需要修改的列,即可完成数据的修改。
  • 查:使用Mapper接口的相应方法,如selectOne()、selectList()等,传入查询条件作为参数,即可完成数据的查询。
    此外,MybatisPlus还支持条件构造器、分页查询等功能,可以根据具体需求进行配置和使用。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/585827.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

h5 history模式是什么

H5 History模式是一种前端路由的实现方式&#xff0c;与Hash模式不同&#xff0c;它利用了HTML5的history API&#xff0c;通过在真实url后面拼接“/”来实现路由的路径。在这种模式下&#xff0c;当“/”后的路径发生变化时&#xff0c;浏览器会重新发起请求&#xff0c;而不是…

C#的checked关键字判断是否溢出

目录 一、定义 二、示例&#xff1a; 三、生成&#xff1a; 一、定义 使用checked关键字处理溢出。 在进行数学运算时&#xff0c;由于变量类型不同&#xff0c;数值的值域也有所不同。如果变量中的数值超出了变量的值域&#xff0c;则会出现溢出情况&#xff0c;出现溢出…

redis安装部署启动

1、Redis概述 1.1 Redis介绍 Redis是用C语言开发的一个开源的高性能键值对&#xff08;key-value&#xff09;数据库。它通过提供多种键值数据类型来适应不同场景下的存储需求&#xff0c;目前为止Redis支持的键值数据类型如下&#xff1a; 字符串类型 散列类型 列表类型 …

12.21自动售货机,单物品,多物品

自动售货机 if朴素方法 一种思路是用寄存器cnt记录已有的最小单位货币量&#xff0c;这里就是0.5 当d1时&#xff0c;cnt1;d2时&#xff0c;cnt2;d3时&#xff0c;cnt4; timescale 1ns/1ns module seller1(input wire clk ,input wire rst ,input wire d1 ,input wire d2 …

vue3 组件之间传值

vue3 组件之间传值 非常好&#xff0c;为啥突然开这样一篇博文&#xff0c;首先是因为 vue3 是未来发展的趋势。其次&#xff0c;vue 官方已经确认&#xff0c;将于2023年最后一天停止对 vue2 项目的维护&#xff0c;这个是官方发出的通知&#xff0c;并且呢&#xff0c;尤雨溪…

Mybatis SQL构建器类 - SQL类

下面是一些例子&#xff1a; // Anonymous inner class public String deletePersonSql() {return new SQL() {{DELETE_FROM("PERSON");WHERE("ID #{id}");}}.toString(); }// Builder / Fluent style public String insertPersonSql() {String sql new…

使用umi中的useRequest函数获取返回值中的data为空的问题

umi是一个react脚手架&#xff0c;最近有一个功能&#xff0c;需要在组件第一次渲染前请求一次&#xff0c;后面组件重新渲染不需要再次发送请求。要实现这种功能&#xff0c;我决定使用umi里面的一个hook函数&#xff0c;即useRequest。请求代码如下 const {data:categorys}u…

使用gitpages搭建博客

1 介绍 博客整体效果。在线预览我的博客&#xff1a;https://taot-chen.github.io 支持特性 简约风格博客Powered By Jekyll博客文章搜索自定义社交链接网站访客统计Google Analytics 网站分析Gitalk评论功能自定义关于about页面支持中文布局支持归档与标签 2 新建博客 git…

AI论文范文:AIGC中的图像转视频技术研究

声明&#xff1a; ⚠️本文由智元兔AI写作大师生成&#xff0c;仅供学习参考智元兔-官网|一站式AI服务平台|AI论文写作|免费论文扩写、翻译、降重神器 1 引言 1.1 AIGC技术背景介绍 1.2 图像转视频技术的重要性与应用场景 1.3 研究动机与目标 2 相关工作回顾 2.1 图像转视…

面试算法78:合并排序链表

题目 输入k个排序的链表&#xff0c;请将它们合并成一个排序的链表。 分析&#xff1a;利用最小堆选取值最小的节点 用k个指针分别指向这k个链表的头节点&#xff0c;每次从这k个节点中选取值最小的节点。然后将指向值最小的节点的指针向后移动一步&#xff0c;再比较k个指…

基于51单片机的智能车寻迹系统设计与实现

一、摘要 随着科技的不断发展&#xff0c;智能车在人们生活中的应用越来越广泛。智能车寻迹系统是智能车的一个重要组成部分&#xff0c;它能够使智能车在各种复杂环境中自动识别并沿着预定的轨迹行驶。本文主要介绍了一种基于单片机的智能车寻迹系统的设计与实现方法。该系统…

统信UOS及麒麟KYLINOS操作系统上设置GRUB密码

原文链接&#xff1a;给单用户模式上一层保险&#xff01;&#xff01;&#xff01; hello&#xff0c;大家好啊&#xff01;今天我要给大家介绍的是在统信UOS及麒麟KYLINOS操作系统上设置GRUB密码的方法。GRUB&#xff08;GRand Unified Bootloader&#xff09;是Linux系统中的…

利用F12和Fiddler抓包

网络基础 http 而http协议又分为下面的部分,点击具体条目后可以查看详细信息 http请求消息:请求行(请求方法),请求路径,请求头,请求体(载荷) http响应消息:响应行(响应状态码),响应头&#xff0c;响应体 请求行 即请求方法 get post put patch 响应行 即响应码,常见响应状态…

祖先是否安宁,直接关系到个人以及家运哦!

一直以来&#xff0c;中国古代流传下来的思想就认为&#xff0c;祖先安葬在好的风水福地&#xff0c;一定能给子孙后代带来吉祥如意。相反的&#xff0c;假如祖坟风水不好&#xff0c;则会影响到后人的运气&#xff0c;轻者诸事不顺、重者家庭破裂、噩运连连&#xff0c;所以&a…

【C++杂货铺】C++11新特性——lambda

文章目录 一、C98中的排序二、先来看看 lambda 表达式长什么样三、lambda表达式语法3.1 捕捉列表的使用细节 四、lambda 的底层原理五、结语 一、C98中的排序 在 C98 中&#xff0c;如果要对一个数据集合中的元素进行排序&#xff0c;可以使用 std::sort 方法&#xff0c;下面…

Nvblox ROS1 安装配置

安装并配置Nvblox ROS1 下载Nvblox ROS1 mkdir -p ~/nvblox_ros1_ws/src/ mkdir ~/data cd ~/nvblox_ros1_ws/src/ git clone https://github.com/ethz-asl/nvblox_ros1.git cd nvblox_ros1 git submodule update --init --recursive安装Docker for pkg in docker.io docke…

二叉树顺序结构与堆的概念及性质(c语言实现堆)

上次介绍了树&#xff0c;二叉树的基本概念结构及性质&#xff1a;二叉树数据结构&#xff1a;深入了解二叉树的概念、特性与结构 今天带来的是&#xff1a;二叉树顺序结构与堆的概念及性质&#xff0c;还会用c语言来实现堆 文章目录 1. 二叉树的顺序结构2.堆的概念和结构3.堆…

推荐几个开源HTTP服务接口快速生成工具

在现在流行微服务、前后端分离软件开发架构下&#xff0c;基于标准RESTful/JSON的HTTP接口已经成为主流。在实际业务中有很多需要快速开发调用数据服务接口的需求&#xff0c;但团队中缺乏专业的后端开发人员&#xff0c;比如&#xff1a; &#xff08;1&#xff09;数据库表已…

PHP开发日志 ━━ 基于PHP和JS的AES相互加密解密方法详解(CryptoJS) 适合CryptoJS4.0和PHP8.0

最近客户在做安全等保&#xff0c;需要后台登录密码采用加密方式&#xff0c;原来用个base64变形一下就算了&#xff0c;现在不行&#xff0c;一定要加密加key加盐~~ 前端使用Cypto-JS加密&#xff0c;传输给后端使用PHP解密&#xff0c;当然&#xff0c;前端虽然有key有盐&…

如何学习计算机编程?零基础入门,轻松成为编程达人!

在这个信息爆炸的时代&#xff0c;计算机编程已经成为一项炙手可热的技能。如果你也对编程充满兴趣&#xff0c;但又不知从何入手&#xff0c;那么本文将为你提供一条通往编程世界的捷径。掌握了这些技巧&#xff0c;相信你一定能够轻松成为编程达人&#xff01; 一、选择合适…