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

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

wptr33 2024-12-15 17:13 40 浏览

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

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

相关推荐

redis的八种使用场景

前言:redis是我们工作开发中,经常要打交道的,下面对redis的使用场景做总结介绍也是对redis举报的功能做梳理。缓存Redis最常见的用途是作为缓存,用于加速应用程序的响应速度。...

基于Redis的3种分布式ID生成策略

在分布式系统设计中,全局唯一ID是一个基础而关键的组件。随着业务规模扩大和系统架构向微服务演进,传统的单机自增ID已无法满足需求。高并发、高可用的分布式ID生成方案成为构建可靠分布式系统的必要条件。R...

基于OpenWrt系统路由器的模式切换与网页设计

摘要:目前商用WiFi路由器已应用到多个领域,商家通过给用户提供一个稳定免费WiFi热点达到吸引客户、提升服务的目标。传统路由器自带的Luci界面提供了工厂模式的Web界面,用户可通过该界面配置路...

这篇文章教你看明白 nginx-ingress 控制器

主机nginx一般nginx做主机反向代理(网关)有以下配置...

如何用redis实现注册中心

一句话总结使用Redis实现注册中心:服务注册...

爱可可老师24小时热门分享(2020.5.10)

No1.看自己以前写的代码是种什么体验?No2.DooM-chip!国外网友SylvainLefebvre自制的无CPU、无操作码、无指令计数器...No3.我认为CS学位可以更好,如...

Apportable:拯救程序员,IOS一秒变安卓

摘要:还在为了跨平台使用cocos2d-x吗,拯救objc程序员的奇葩来了,ApportableSDK:FreeAndroidsupportforcocos2d-iPhone。App...

JAVA实现超买超卖方案汇总,那个最适合你,一篇文章彻底讲透

以下是几种Java实现超买超卖问题的核心解决方案及代码示例,针对高并发场景下的库存扣减问题:方案一:Redis原子操作+Lua脚本(推荐)//使用Redis+Lua保证原子性publicbo...

3月26日更新 快速施法自动施法可独立设置

2016年3月26日DOTA2有一个79.6MB的更新主要是针对自动施法和快速施法的调整本来内容不多不少朋友都有自动施法和快速施法的困扰英文更新日志一些视觉BUG修复就不翻译了主要翻译自动施...

Redis 是如何提供服务的

在刚刚接触Redis的时候,最想要知道的是一个’setnameJhon’命令到达Redis服务器的时候,它是如何返回’OK’的?里面命令处理的流程如何,具体细节怎么样?你一定有问过自己...

lua _G、_VERSION使用

到这里我们已经把lua基础库中的函数介绍完了,除了函数外基础库中还有两个常量,一个是_G,另一个是_VERSION。_G是基础库本身,指向自己,这个变量很有意思,可以无限引用自己,最后得到的还是自己,...

China&#39;s top diplomat to chair third China-Pacific Island countries foreign ministers&#39; meeting

BEIJING,May21(Xinhua)--ChineseForeignMinisterWangYi,alsoamemberofthePoliticalBureau...

移动工作交流工具Lua推出Insights数据分析产品

Lua是一个适用于各种职业人士的移动交流平台,它在今天推出了一项叫做Insights的全新功能。Insights是一个数据平台,客户可以在上面实时看到员工之间的交流情况,并分析这些情况对公司发展的影响...

Redis 7新武器:用Redis Stack实现向量搜索的极限压测

当传统关系型数据库还在为向量相似度搜索的性能挣扎时,Redis7的RedisStack...

Nginx/OpenResty详解,Nginx Lua编程,重定向与内部子请求

重定向与内部子请求Nginx的rewrite指令不仅可以在Nginx内部的server、location之间进行跳转,还可以进行外部链接的重定向。通过ngx_lua模块的Lua函数除了能实现Nginx...