百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

Spring Boot(十一):MyBatis插件之MyBatis-Plus

yuyutoo 2024-10-12 00:03 3 浏览 0 评论

MyBatis-Plus简介

MyBatis的插件MyBatis-Plus,又叫苞米豆(baomidou),简称MP,官方说,它是为了猿类崛起而生,为了提高生产率而生,为了简化开发而生,不管它为了什么而生吧,反正是它出生了。

MyBatis-Plus对MyBatis只做增强不做改变,所以引入它不会对现有工程产生影响,只需要做简单的配置,就可以快速进行单表的CRUD操作,从而节省时间,提高效率。

MyBatis-Plus插件有很丰富的功能,比如:单表CRUD操作、代码生成、自动分页、逻辑删除等。

MyBatis-Plus使用

下面我们来简单介绍一下MyBatis-Plus的使用

1、pom.xml

去掉MyBatis的核心依赖(org.mybatis.spring.boot.mybatis-spring-boot-starter),增加MyBatis-Plus的依赖:

<!-- MyBatis-Plus依赖 --> 
<dependency> 
    <groupId>com.baomidou</groupId> 
    <artifactId>mybatis-plus-boot-starter</artifactId> 
    <version>3.5.1</version> 
</dependency>

2、配置application.yml、po、dao和Application

application.yml中配置数据库连接:

spring: 
  datasource: 
    url: jdbc:mysql://localhost:3306/blog 
    username: root 
    password: 123456 
    type: com.alibaba.druid.pool.DruidDataSource 
    druid: 
      initialSize: 5 
      minIdle: 5 
      maxActive: 20 
      maxWait: 2000 
      validationQuery: select 'x' 
      testOnBorrow: false 
      testOnReturn: false 
      testWhileIdle: true 

blog数据库中article表的实体类ArticlePo:

@TableName(value = "article") 
public class ArticlePo { 

    @TableId(type = IdType.AUTO) 
    private Integer id; 
    private String articleId; 
    private String title; 

    // get、set... 
} 

注解说明:

@TableName:表名注解,标识实体类对应的表

@TableId注解:主键注解,当type = IdType.AUTO时,表示这个主键是自增主键

blog数据库中article表的dao,ArticleDao:

@Repository 
public interface ArticleDao extends BaseMapper<ArticlePo> { 
} 

BaseMapper接口:利用Mybatis接口编程的实现机制,默认提供了一系列的增删改查的基础方法。

在Article11Application中配置 MapperScan 注解:

@SpringBootApplication 
@MapperScan(basePackages = "com.tn222.springboot.article11.dao") 
public class Article11Application { 

    public static void main(String[] args) { 
        SpringApplication.run(Article11Application.class, args); 
    } 

} 

3、增加数据

insert:增加数据,insert返回值int代表insert了多少条记录

示例:在ArticleController中编写增加数据的接口:

@Resource 
private ArticleDao articleDao; 

@PostMapping("/insert") 
public int insert() { 
    String articleId = UUID.randomUUID().toString().replace("-", ""); 
    ArticlePo articlePo = new ArticlePo(); 
    articlePo.setArticleId(articleId); 
    articlePo.setTitle("Mybatis-Plus test"); 
    int num = articleDao.insert(articlePo); 
    return num; 
} 

说明:

1)一般业务逻辑处理在service层,这里为了方便,直接在controller中演示了

2)@Resource注解:注入ArticleDao,后续的方法中不再重复注入

4、删除数据

delete:物理删除数据,返回删除了多少条数据

示例,删除title为Mybatis-Plus test的数据:

@PostMapping("/delete") 
public int delete() { 
    int num = articleDao.delete(Wrappers.<ArticlePo>lambdaQuery() 
            .eq(ArticlePo::getTitle, "Mybatis-Plus test")); 
    return num; 
} 

说明:

1)物理删除后,恢复数据很困难,所以一般情况下,业务处理采用逻辑删除的方式

5、更新数据

update: 更新数据

示例,修改title为Mybatis-Plus test的数据的title为Mybatis-Plus update:

@PostMapping("/update") 
public int update() { 
    ArticlePo articlePo = new ArticlePo(); 
    articlePo.setTitle("Mybatis-Plus update"); 

    int num = articleDao.update(articlePo, Wrappers.<ArticlePo>lambdaUpdate() 
            .eq(ArticlePo::getTitle, "Mybatis-Plus test")); 
    return  num; 
} 

updateById: 根据主键id更新数据

示例,修改id为7的数据的title为Mybatis-Plus updateById:

@PostMapping("/updateById") 
public int updateById() { 
    ArticlePo articlePo = new ArticlePo(); 
    articlePo.setId(7); 
    articlePo.setTitle("Mybatis-Plus updateById"); 
    int num = articleDao.updateById(articlePo); 
    return num; 
} 

注意??:

1、updateById方法:若传入实体Model,则会根据主键把其他字段全部更新一遍

问题:使用baomidou拿出某条数据的数据实体后,有其他人把数据库中这条数据的某个字段更新了,再用baomidou的updateById方法更新时,会把此字段再更新回来

解决:

方法1:使用sql语句,只更新需要更新的字段

方法2:新建实体Model,Model中只放主键和需要更新的字段

6、查询数据

selectOne: 查询单条数据

示例,查询id为7的数据:

@GetMapping("/selectOne") 
public Object selectOne() { 
    ArticlePo articlePo = articleDao.selectOne(Wrappers.<ArticlePo>lambdaQuery() 
            .eq(ArticlePo::getId, "7")); 
    return articlePo; 
} 

注意??:

1、selectOne方法

1)结果没有数据时,返回null

2)结果有一条数据时,返回此数据

3)结果有两条或两条以上数据时,报错

解决办法:在最后增加 .last(" limit 1 ") 语句

selectList: 查询多条数据

示例:查询title为Mybatis-Plus update的数据

@GetMapping("/selectList") 
public Object selectList() { 
    List<ArticlePo> articlePoList = articleDao.selectList(Wrappers.<ArticlePo>lambdaQuery() 
            .eq(ArticlePo::getTitle, "Mybatis-Plus update")); 
    return articlePoList; 
} 

7、打印sql日志

打印执行的sql,在application.yml中配置,一般配置在开发环境

mybatis-plus: 
  configuration: 
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl 

MyBatis-Plus的其他注意事项??

1、如果数据库表字段中有desc、describe等mysql关键词或预留关键词,使用selectList/selectOne会报错,需要单独写sql查询语句

2、有时我们需要在Dao中单独写方法来写sql语句,这时方法的命名跟baomidou自带的命名不要一样,否则即使参数不同,也会有问题:Dao中单独写的方法,会把baomidou的方法覆盖,就调用不到baomidou的方法了

本文示例代码,详见
https://gitee.com/tunan222/spring-boot-demo

若您觉得还可以,请帮忙点个“赞”,谢谢~

相关推荐

jQuery VS AngularJS 你更钟爱哪个?

在这一次的Web开发教程中,我会尽力解答有关于jQuery和AngularJS的两个非常常见的问题,即jQuery和AngularJS之间的区别是什么?也就是说jQueryVSAngularJS?...

Jquery实时校验,指定长度的「负小数」,小数位未满末尾补0

在可以输入【负小数】的输入框获取到焦点时,移除千位分隔符,在输入数据时,实时校验输入内容是否正确,失去焦点后,添加千位分隔符格式化数字。同时小数位未满时末尾补0。HTML代码...

如何在pbootCMS前台调用自定义表单?pbootCMS自定义调用代码示例

要在pbootCMS前台调用自定义表单,您需要在后台创建表单并为其添加字段,然后在前台模板文件中添加相关代码,如提交按钮和表单验证代码。您还可以自定义表单数据的存储位置、添加文件上传字段、日期选择器、...

编程技巧:Jquery实时验证,指定长度的「负小数」

为了保障【负小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【负小数】的方法。HTML代码<inputtype="text"class="forc...

一篇文章带你用jquery mobile设计颜色拾取器

【一、项目背景】现实生活中,我们经常会遇到配色的问题,这个时候去百度一下RGB表。而RGB表只提供相对于的颜色的RGB值而没有可以验证的模块。我们可以通过jquerymobile去设计颜色的拾取器...

编程技巧:Jquery实时验证,指定长度的「正小数」

为了保障【正小数】的正确性,做成了通过Jquery,在用户端,实时验证指定长度的【正小数】的方法。HTML做成方法<inputtype="text"class="fo...

jquery.validate检查数组全部验证

问题:html中有多个name[],每个参数都要进行验证是否为空,这个时候直接用required:true话,不能全部验证,只要这个数组中有一个有值就可以通过的。解决方法使用addmethod...

Vue进阶(幺叁肆):npm查看包版本信息

第一种方式npmviewjqueryversions这种方式可以查看npm服务器上所有的...

layui中使用lay-verify进行条件校验

一、layui的校验很简单,主要有以下步骤:1.在form表单内加上class="layui-form"2.在提交按钮上加上lay-submit3.在想要校验的标签,加上lay-...

jQuery是什么?如何使用? jquery是什么功能组件

jQuery于2006年1月由JohnResig在BarCampNYC首次发布。它目前由TimmyWilson领导,并由一组开发人员维护。jQuery是一个JavaScript库,它简化了客户...

django框架的表单form的理解和用法-9

表单呈现...

jquery对上传文件的检测判断 jquery实现文件上传

总体思路:在前端使用jquery对上传文件做部分初步的判断,验证通过的文件利用ajaxFileUpload上传到服务器端,并将文件的存储路径保存到数据库。<asp:FileUploadI...

Nodejs之MEAN栈开发(四)-- form验证及图片上传

这一节增加推荐图书的提交和删除功能,来学习node的form提交以及node的图片上传功能。开始之前需要源码同学可以先在git上fork:https://github.com/stoneniqiu/R...

大数据开发基础之JAVA jquery 大数据java实战

上一篇我们讲解了JAVAscript的基础知识、特点及基本语法以及组成及基本用途,本期就给大家带来了JAVAweb的第二个知识点jquery,大数据开发基础之JAVAjquery,这是本篇文章的主要...

推荐四个开源的jQuery可视化表单设计器

jquery开源在线表单拖拉设计器formBuilder(推荐)jQueryformBuilder是一个开源的WEB在线html表单设计器,开发人员可以通过拖拉实现一个可视化的表单。支持表单常用控件...

取消回复欢迎 发表评论: