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

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

yuyutoo 2024-10-12 00:03 10 浏览 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

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

相关推荐

ETCD 故障恢复(etc常见故障)

概述Kubernetes集群外部ETCD节点故障,导致kube-apiserver无法启动。...

在Ubuntu 16.04 LTS服务器上安装FreeRADIUS和Daloradius的方法

FreeRADIUS为AAARadiusLinux下开源解决方案,DaloRadius为图形化web管理工具。...

如何排查服务器被黑客入侵的迹象(黑客 抓取服务器数据)

---排查服务器是否被黑客入侵需要系统性地检查多个关键点,以下是一份详细的排查指南,包含具体命令、工具和应对策略:---###**一、快速初步检查**####1.**检查异常登录记录**...

使用 Fail Ban 日志分析 SSH 攻击行为

通过分析`fail2ban`日志可以识别和应对SSH暴力破解等攻击行为。以下是详细的操作流程和关键分析方法:---###**一、Fail2ban日志位置**Fail2ban的日志路径因系统配置...

《5 个实用技巧,提升你的服务器安全性,避免被黑客盯上!》

服务器的安全性至关重要,特别是在如今网络攻击频繁的情况下。如果你的服务器存在漏洞,黑客可能会利用这些漏洞进行攻击,甚至窃取数据。今天我们就来聊聊5个实用技巧,帮助你提升服务器的安全性,让你的系统更...

聊聊Spring AI Alibaba的YuQueDocumentReader

序本文主要研究一下SpringAIAlibaba的YuQueDocumentReaderYuQueDocumentReader...

Mac Docker环境,利用Canal实现MySQL同步ES

Canal的使用使用docker环境安装mysql、canal、elasticsearch,基于binlog利用canal实现mysql的数据同步到elasticsearch中,并在springboo...

RustDesk:开源远程控制工具的技术架构与全场景部署实战

一、开源远程控制领域的革新者1.1行业痛点与解决方案...

长安汽车一代CS75Plus2020款安装高德地图7.5

不用破解原车机,一代CS75Plus2020款,安装车机版高德地图7.5,有红绿灯读秒!废话不多讲,安装步骤如下:一、在拨号状态输入:在电话拨号界面,输入:*#518200#*(进入安卓设置界面,...

Zookeeper使用详解之常见操作篇(zookeeper ui)

一、Zookeeper的数据结构对于ZooKeeper而言,其存储结构类似于文件系统,也是一个树形目录服务,并通过Key-Value键值对的形式进行数据存储。其中,Key由斜线间隔的路径元素构成。对...

zk源码—4.会话的实现原理一(会话层的基本功能是什么)

大纲1.创建会话...

Zookeeper 可观测性最佳实践(zookeeper能够确保)

Zookeeper介绍ZooKeeper是一个开源的分布式协调服务,用于管理和协调分布式系统中的节点。它提供了一种高效、可靠的方式来解决分布式系统中的常见问题,如数据同步、配置管理、命名服务和集群...

服务器密码错误被锁定怎么解决(服务器密码错几次锁)

#服务器密码错误被锁定解决方案当服务器因多次密码错误导致账户被锁定时,可以按照以下步骤进行排查和解决:##一、确认锁定状态###1.检查账户锁定状态(Linux)```bash#查看账户锁定...

zk基础—4.zk实现分布式功能(分布式zk的使用)

大纲1.zk实现数据发布订阅...

《死神魂魄觉醒》卡死问题终极解决方案:从原理到实战的深度解析

在《死神魂魄觉醒》的斩魄刀交锋中,游戏卡死犹如突现的虚圈屏障,阻断玩家与尸魂界的连接。本文将从技术架构、解决方案、预防策略三个维度,深度剖析卡死问题的成因与应对之策,助力玩家突破次元壁障,畅享灵魂共鸣...

取消回复欢迎 发表评论: