【愚公系列】2023年11月 Java教学课程 177-MyBatisPlus(通用配置)

2023-11-11 09:40

本文主要是介绍【愚公系列】2023年11月 Java教学课程 177-MyBatisPlus(通用配置),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

🏆 作者简介,愚公搬代码
🏆《头衔》:华为云特约编辑,华为云云享专家,华为开发者专家,华为产品云测专家,CSDN博客专家,阿里云专家博主,阿里云签约作者,腾讯云优秀博主,腾讯云内容共创官,掘金优秀博主,51CTO博客专家等。
🏆《近期荣誉》:2022年CSDN博客之星TOP2,2022年华为云十佳博主等。
🏆《博客内容》:.NET、Java、Python、Go、Node、前端、IOS、Android、鸿蒙、Linux、物联网、网络安全、大数据、人工智能、U3D游戏、小程序等相关领域知识。
🏆🎉欢迎 👍点赞✍评论⭐收藏

文章目录

  • 🚀前言
  • 🚀一、DML编程控制
    • 🔎1.id生成策略控制(Insert)
      • 🦋1.1 id生成策略控制(@TableId注解)
      • 🦋1.2 全局策略配置
        • ☀️1.2.1 id生成策略全局配置
        • ☀️1.2.2 表名前缀全局配置
    • 🔎2.多记录操作(批量Delete/Select)
      • 🦋2.1 按照主键删除多条记录
      • 🦋2.2 根据主键查询多条记录
    • 🔎3.逻辑删除(Delete/Update)
      • 🦋3.1 逻辑删除案例
        • ☀️3.1.1 数据库表中添加逻辑删除标记字段
        • ☀️3.1.2 实体类中添加对应字段,并设定当前字段为逻辑删除标记字段
        • ☀️3.1.3 配置逻辑删除字面值
    • 🔎4.乐观锁(Update)
      • 🦋4.1 问题导入
      • 🦋4.2 什么是悲观锁和乐观锁
      • 🦋4.3 乐观锁案例
        • ☀️4.3.1 数据库表中添加锁标记字段
        • ☀️4.3.2 实体类中添加对应字段,并设定当前字段为版本控制字段
        • ☀️4.3.3 配置乐观锁拦截器实现锁机制对应的动态SQL语句拼装
        • ☀️4.3.4 使用乐观锁机制在修改前必须先获取到对应数据的version方可正常进行
  • 🚀感谢:给读者的一封信


🚀前言

DML是数据库操作语言(Data Manipulation Language)的简称,用于对数据库中的数据进行增删改查,是数据库编程操作中最基本的语言之一。在关系型数据库中,数据存储在表格中,使用DML语句可以对表格中的数据进行各种操作。

常见的DML语句包括:

  1. INSERT:用于向数据库表格中插入新数据。

  2. UPDATE:用于修改数据库表格中的数据。

  3. DELETE:用于删除数据库表格中的数据。

  4. SELECT:用于从数据库表格中检索数据,可以指定查询的条件和返回的列。

除了以上常见的DML语句,DML语言还可以使用一些其他的关键字和操作符对数据进行操作,比如:

  1. WHERE:用于指定查询条件,限制查询结果集。

  2. ORDER BY:用于指定查询结果集的排序顺序。

  3. GROUP BY:用于将查询结果集按照指定列进行分组。

  4. JOIN:用于合并不同表格中的数据,实现数据的关联和查询。

使用DML语句可以对数据库表格中的数据进行非常灵活的操作,可以满足不同的业务需求。在数据库编程中,DML语句是基础中的基础,需要掌握才能够熟练地进行数据库编程。

🚀一、DML编程控制

🔎1.id生成策略控制(Insert)

🦋1.1 id生成策略控制(@TableId注解)

  • 名称:@TableId

  • 类型:属性注解

  • 位置:模型类中用于表示主键的属性定义上方

  • 作用:设置当前类中主键属性的生成策略

  • 相关属性

    type:设置主键属性的生成策略,值参照IdType枚举值

    在这里插入图片描述

针对每个公司,随着服务化演进,单个服务越来越多,数据库分的越来越细,有的时候一个业务需要分成好几个库,这时候自增主键或者序列之类的主键id生成方式已经不再满足需求,分布式系统中需要的是一个全局唯一的id生成规则。

具体的算法和代码,参见资料文件夹。

uuid生成的字符串,不是自增长,字符串作为主键查询速度,存储值是不连续的,查询慢

雪花算法:固定长度,全部数字(Long),增长的趋势,存储是连续的,查询速度快

添加无参和有参的构造方法

@Data
@TableName("tbl_user")
public class User {public User() {}public User(Long id, String name, String gender, String password, Integer age, String tel) {this.id = id;this.name = name;this.gender = gender;this.password = password;this.age = age;this.tel = tel;}//使用雪花算法@TableId(type = IdType.ASSIGN_ID)private Long id;private String name;private String gender;@TableField("pwd")private String password;private Integer age;private String tel;
}

测试

@Test
void insertUser() {//创建用户User user = new User(null,"孙悟天","男","12345",8,"15022334455");UserMapper.insert(user);
}

执行的SQL语句

在这里插入图片描述

🦋1.2 全局策略配置

也可以在application.yml中进行全局的配置

  1. id-type 让所有表主键生成策略相同
  2. table-prefix 在每个实体类的前面添加相同的前缀
mybatis-plus:global-config:db-config:id-type: assign_idtable-prefix: tbl_
☀️1.2.1 id生成策略全局配置

在这里插入图片描述

☀️1.2.2 表名前缀全局配置

在这里插入图片描述

实体类:去了@TableName注解和@TableId

@Data
public class User {public User() {}public User(Long id, String name, String gender, String password, Integer age, String tel) {this.id = id;this.name = name;this.gender = gender;this.password = password;this.age = age;this.tel = tel;}private Long id;private String name;private String gender;@TableField("pwd")private String password;private Integer age;private String tel;
}

🔎2.多记录操作(批量Delete/Select)

🦋2.1 按照主键删除多条记录

使用方法:deleteBatchIds()

//删除指定多条数据
List<Long> list = new ArrayList<>();
list.add(1402551342481838081L);
list.add(1402553134049501186L);
list.add(1402553619611430913L);userMapper.deleteBatchIds(list);

生成的SQL语句

 DELETE FROM tbl_user WHERE id IN ( ? , ? , ? )

🦋2.2 根据主键查询多条记录

使用方法:selectBatchIds()

 //注意:MP数据访问层没有实现批量插入,但是业务层有实现
@Test
public void testSelectBatchIds(){//查询指定多条数据List<Long> list = new ArrayList<>();list.add(1L);list.add(3L);list.add(4L);List<User> userList = userMapper.selectBatchIds(list);userList.forEach(System.out::println);
}

生成的SQL语句

SELECT id,name,gender,pwd AS password,age,tel FROM tbl_user WHERE id IN ( ? , ? , ? )

🔎3.逻辑删除(Delete/Update)

🦋3.1 逻辑删除案例

修改表结构

-- 添加一列deleted,注意设置默认值为0
ALTER TABLE tbl_user ADD COLUMN deleted INT(1) DEFAULT 0;-- 查看结构
DESC tbl_user;
☀️3.1.1 数据库表中添加逻辑删除标记字段

在这里插入图片描述

☀️3.1.2 实体类中添加对应字段,并设定当前字段为逻辑删除标记字段

@TableLogic包含以下属性

  • value:未删除时的值

  • delval:删除了的值

@Data
public class User {private Long id;//逻辑删除字段,标记当前记录是否被删除@TableLogicprivate Integer deleted;}
☀️3.1.3 配置逻辑删除字面值
mybatis-plus:global-config:db-config:table-prefix: tbl_# 逻辑删除字段名logic-delete-field: deleted# 逻辑删除字面值:未删除为0logic-not-delete-value: 0# 逻辑删除字面值:删除为1logic-delete-value: 1

逻辑删除本质:逻辑删除的本质其实是修改操作。如果加了逻辑删除字段,查询数据时也会自动带上逻辑删除字段。

@Test
void testLogicDeleted() {int row = UserMapper.deleteById(5);System.out.println(row + "条记录被逻辑删除");
}

在这里插入图片描述

🔎4.乐观锁(Update)

🦋4.1 问题导入

乐观锁主张的思想是什么?

  • 业务并发现象带来的问题:秒杀

在这里插入图片描述

🦋4.2 什么是悲观锁和乐观锁

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

在这里插入图片描述

🦋4.3 乐观锁案例

☀️4.3.1 数据库表中添加锁标记字段
ALTER TABLE tbl_user ADD COLUMN `version` INT DEFAULT 0;

在这里插入图片描述

☀️4.3.2 实体类中添加对应字段,并设定当前字段为版本控制字段

@Version注解

package com.itheima.domain;@Data
public class User {private Long id;@Versionprivate Integer version;
}
☀️4.3.3 配置乐观锁拦截器实现锁机制对应的动态SQL语句拼装
package com.itheima.config;@Configuration
public class MybatisPlusConfig {@Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {//1.定义Mp拦截器MybatisPlusInterceptor mpInterceptor = new MybatisPlusInterceptor();//2.添加乐观锁拦截器mpInterceptor.addInnerInterceptor(new OptimisticLockerInnerInterceptor());return mpInterceptor;}
}
☀️4.3.4 使用乐观锁机制在修改前必须先获取到对应数据的version方可正常进行
@Test
public void testUpdateOne() {//1.先通过要修改的数据id将当前数据查询出来User user = userMapper.selectById(2L);//2.将要修改的属性逐一设置进去user.setName("Jock888");userMapper.updateById(user);
}

在这里插入图片描述

模拟多条记录同时更新

@Test
public void testUpdateTwo() {//先通过要修改的数据id将当前数据查询出来User user1 = userMapper.selectById(2L);     //version=2User user2 = userMapper.selectById(2L);    //version=2user1.setName("Jack aaa");userMapper.updateById(user1);              //version=>3user2.setName("Jack bbb");userMapper.updateById(user2);               //verion=2 更新失败
}

第二条记录更新失败

在这里插入图片描述


🚀感谢:给读者的一封信

亲爱的读者,

我在这篇文章中投入了大量的心血和时间,希望为您提供有价值的内容。这篇文章包含了深入的研究和个人经验,我相信这些信息对您非常有帮助。

如果您觉得这篇文章对您有所帮助,我诚恳地请求您考虑赞赏1元钱的支持。这个金额不会对您的财务状况造成负担,但它会对我继续创作高质量的内容产生积极的影响。

我之所以写这篇文章,是因为我热爱分享有用的知识和见解。您的支持将帮助我继续这个使命,也鼓励我花更多的时间和精力创作更多有价值的内容。

如果您愿意支持我的创作,请扫描下面二维码,您的支持将不胜感激。同时,如果您有任何反馈或建议,也欢迎与我分享。

在这里插入图片描述

再次感谢您的阅读和支持!

最诚挚的问候, “愚公搬代码”

这篇关于【愚公系列】2023年11月 Java教学课程 177-MyBatisPlus(通用配置)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/389169

相关文章

Java设计模式---迭代器模式(Iterator)解读

《Java设计模式---迭代器模式(Iterator)解读》:本文主要介绍Java设计模式---迭代器模式(Iterator),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,... 目录1、迭代器(Iterator)1.1、结构1.2、常用方法1.3、本质1、解耦集合与遍历逻辑2、统一

Java内存分配与JVM参数详解(推荐)

《Java内存分配与JVM参数详解(推荐)》本文详解JVM内存结构与参数调整,涵盖堆分代、元空间、GC选择及优化策略,帮助开发者提升性能、避免内存泄漏,本文给大家介绍Java内存分配与JVM参数详解,... 目录引言JVM内存结构JVM参数概述堆内存分配年轻代与老年代调整堆内存大小调整年轻代与老年代比例元空

深度解析Java DTO(最新推荐)

《深度解析JavaDTO(最新推荐)》DTO(DataTransferObject)是一种用于在不同层(如Controller层、Service层)之间传输数据的对象设计模式,其核心目的是封装数据,... 目录一、什么是DTO?DTO的核心特点:二、为什么需要DTO?(对比Entity)三、实际应用场景解析

Java 线程安全与 volatile与单例模式问题及解决方案

《Java线程安全与volatile与单例模式问题及解决方案》文章主要讲解线程安全问题的五个成因(调度随机、变量修改、非原子操作、内存可见性、指令重排序)及解决方案,强调使用volatile关键字... 目录什么是线程安全线程安全问题的产生与解决方案线程的调度是随机的多个线程对同一个变量进行修改线程的修改操

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

SpringBoot整合liteflow的详细过程

《SpringBoot整合liteflow的详细过程》:本文主要介绍SpringBoot整合liteflow的详细过程,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋...  liteflow 是什么? 能做什么?总之一句话:能帮你规范写代码逻辑 ,编排并解耦业务逻辑,代码

JavaSE正则表达式用法总结大全

《JavaSE正则表达式用法总结大全》正则表达式就是由一些特定的字符组成,代表的是一个规则,:本文主要介绍JavaSE正则表达式用法的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录常用的正则表达式匹配符正则表China编程达式常用的类Pattern类Matcher类PatternSynta

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S