pc网站怎么做,网站设计师证书,淘宝网页版本,wordpress放音乐播放器目录
1 快速开始
1.1 依赖准备
1.2 配置准备
1.3 启动服务
2 使用
2.1 实体类注解
2.2 CRUD
2.3 分页
2.4 逻辑删除配置
2.5 通用枚举配置
2.6 自动填充
2.7 多数据源
3 测试 本文主要介绍 mybatis-plus 这款插件#xff0c;针对 springboot 用户。包括引入…目录
1 快速开始
1.1 依赖准备
1.2 配置准备
1.3 启动服务
2 使用
2.1 实体类注解
2.2 CRUD
2.3 分页
2.4 逻辑删除配置
2.5 通用枚举配置
2.6 自动填充
2.7 多数据源
3 测试 本文主要介绍 mybatis-plus 这款插件针对 springboot 用户。包括引入配置使用以及扩展等常用的方面做一个汇总整理尽量包含大家常用的场景内容。 关于 mybatis-plus 是什么不多做介绍了看官方文档咱们直接代码撸起来。
1 快速开始 本文基于 springboot、maven、jdk1.8、mysql 开发所以开始前我们需要准备好这套环境。我的环境使用了 nacos 作为注册中心不了解或需要搭建的参考 https://juejin.cn/post/7053977860612030477 新建如下数据库 建议大家选择 utf8mb4 这种字符集做过微信的同学应该会知道微信用户名称的表情是需要这种字符集才能存储的。 我就默认其他环境已经准备好了咱们直接从 mybatis-plus 开始。
1.1 依赖准备
想要什么依赖版本的去 maven 仓库查看 https://mvnrepository.com/ 引入 mybatis-plus 依赖
dependencygroupIdcom.baomidou/groupIdartifactIdmybatis-plus-boot-starter/artifactIdversion3.5.0/version
/dependency
引入 mysql 依赖
dependencygroupIdmysql/groupIdartifactIdmysql-connector-java/artifactIdversion8.0.27/version
/dependency 目前多数项目会有多数据源的要求或者是主从部署的要求所以我们还需要引入 mybatis-plus 关于多数据源的依赖
dependencygroupIdcom.baomidou/groupIdartifactIddynamic-datasource-spring-boot-starter/artifactIdversion3.5.0/version
/dependency
1.2 配置准备
springboot 启动类。配置MapperScan 注解用于扫描 Mapper 文件位置:
EnableDiscoveryClient
MapperScan(\com.wjbgn.user.mapper\)
SpringBootApplication
public class RobNecessitiesUserApplication {public static void main(String[] args) {SpringApplication.run(RobNecessitiesUserApplication.class, args);}
}
数据源配置此处配置一主一从的环境当前我只有一台所以此处配置一样的
spring:datasource:dynamic:primary: master #设置默认的数据源或者数据源组,默认值即为masterstrict: false #严格匹配数据源,默认false. true未匹配到指定数据源时抛异常,false使用默认数据源datasource:master:url: jdbc:mysql://127.0.0.1:3306/rob_necessities?useUnicodetruecharacterEncodingutf-8useSSLfalseserverTimezone Asia/Shanghaiusername: rootpassword: 123456slave_1:url: jdbc:mysql://127.0.0.1:3306/rob_necessities?useUnicodetruecharacterEncodingutf-8useSSLfalseserverTimezone Asia/Shanghaiusername: rootpassword: 123456 补充这里面因为默认使用的是HikariCP数据源目前也推荐使用这个相比于druid有更高的性能但是不能忽略下面的配置否则服务会不断抛出异常原因是数据库的连接时长和连接池的配置没有做好。
spring:datasource:dynamic:hikari:max-lifetime: 1800000connection-timeout: 5000idle-timeout: 3600000max-pool-size: 12min-idle: 4connection-test-query: /**ping*/
1.3 启动服务
下面直接启动服务 得到如上结果表示启动成功了。
2 使用 前面我们成功的集成进来了 mybatis-plus配合 springboot 使用不要太方便。下面我们看看如何使用它来操作我们的数据库。介绍一下常规的用法。
2.1 实体类注解 mybatis-plus 为使用者封装了很多的注解方便我们使用我们首先看下实体类中有哪些注解。有如下的实体类
TableName(value \user\)
public class UserDO {/*** 主键*/TableId(value \id\, type IdType.AUTO)private Long id;/*** 昵称*/TableField(\nickname\)private String nickname;/*** 真实姓名*/private String realName;
}
TableName 表名注解用于标识实体类对应的表。
其说明如下关于这些书写常规情况基本很少用到不做多余解释了
Documented
Retention(RetentionPolicy.RUNTIME)
Target({ElementType.TYPE, ElementType.ANNOTATION_TYPE})
public interface TableName {/*** 实体对应的表名*/String value() default \\;/*** schema* since 3.1.1*/String schema() default \\;/*** 是否保持使用全局的 tablePrefix 的值* p 只生效于 既设置了全局的 tablePrefix 也设置了上面 {link #value()} 的值 /p* li 如果是 false , 全局的 tablePrefix 不生效 /li** since 3.1.1*/boolean keepGlobalPrefix() default false;/*** 实体映射结果集,* 只生效与 mp 自动注入的 method*/String resultMap() default \\;/*** 是否自动构建 resultMap 并使用,* 只生效与 mp 自动注入的 method,* 如果设置 resultMap 则不会进行 resultMap 的自动构建并注入,* 只适合个别字段 设置了 typeHandler 或 jdbcType 的情况** since 3.1.2*/boolean autoResultMap() default false;/*** 需要排除的属性名** since 3.3.1*/String[] excludeProperty() default {};
}
TableId 主键注解
看看其源码
Documented
Retention(RetentionPolicy.RUNTIME)
Target({ElementType.FIELD, ElementType.ANNOTATION_TYPE})
public interface TableId {/*** 字段值驼峰命名方式该值可无*/String value() default \\;/*** 主键ID* {link IdType}*/IdType type() default IdType.NONE;
}
其中 IdType 很重要 TableFiled 表字段标识
下面看看其主要常用属性 关于其他的属性我不太推荐使用用得越多越容易蒙圈。可以通过 wapper 查询去设置。
2.2 CRUD mybatis-plus 封装好了一条接口供我们直接调用。关于内部的具体方法在使用时候自己体会吧此处不列举了。
2.2.1 Service 层 CRUD
我们使用的时候需要在自己定义的 service 接口当中继承 IService 接口
/*** description用户服务接口* version3.0*/
public interface IUserService extends IServiceUserDO {
}
同时要在我们的接口实现 impl 当中继承 ServiceImpl实现自己的接口
/*** description用户接口实现* version3.0*/
public class UserServiceImpl extends ServiceImplUserMapper, UserDO implements IUserService {}
2.2.2 Mapper 层 CRUD mybatis-plus 将常用的 CRUD 接口封装成了BaseMapper接口我们只需要在自己的 Mapper 中继承它就可以了
/*** description用户mapper* version3.0*/
Mapper
public interface UserMapper extends BaseMapperUserDO {
}
2.3 分页
使用分页话需要增加分页插件的配置
Configuration
MapperScan(\com.wjbgn.*.mapper*\)
public class MybatisPlusConfig {Beanpublic MybatisPlusInterceptor mybatisPlusInterceptor() {MybatisPlusInterceptor interceptor new MybatisPlusInterceptor();interceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));return interceptor;}}
如上配置后我们直接使用分页方法就行。
2.4 逻辑删除配置 很多情况下我们的系统都需要逻辑删除方便恢复查找误删除的数据。 通过 mybatis-plus 可以通过全局配置的方式而不需要再去手动处理。针对更新和查询操作有效新增不做限制。 通常以我的习惯逻辑删除字段通常定义为is_delete在实体类当中就是isDelete。那么在配置文件中就可以有如下的配置
mybatis-plus:global-config:db-config:logic-delete-field: isDelete # 全局逻辑删除的实体字段名(since 3.3.0,配置后可以忽略不配置步骤2)logic-delete-value: 1 # 逻辑已删除值(默认为 1)logic-not-delete-value: 0 # 逻辑未删除值(默认为 0)
或者通过注解TableLogic
TableLogic
private Integer isDelete;
2.5 通用枚举配置 相信后端的同学都经历过一个情况比如性别这个字段分别值和名称对应1男、2女这个字段在数据库时是数值类型而前端展示则是展示字符串的名称。有几种常见实现方案呢 ·数据库查询 sql 通过 case 判断返回名称以前 oracle 经常这么做 ·数据库返回的值重新遍历赋值进去这时候还需要判断这个值到底是男是女。 ·前端写死返回 1 就是男返回 2 就是女。 相信无论哪种方法都有其缺点所以我们可以使用 mybatis-plus 提供的方式。我们在返回给前端时 ·只需要在遍历时 get 这个枚举直接赋值其名称不需要再次判断。 ·直接返回给前端让前端去枚举的 name
这样大家都不需要写死这个值。下面看看如何实现这个功能
1. 定义枚举实现 IEnum 接口
/*** description性别枚举* version3.0*/
JsonFormat(shape JsonFormat.Shape.OBJECT)
public enum SexEnum implements IEnumInteger {MAN(1, \男\),WOMAN(2, \女\);private Integer code;private String name;SexEnum(Integer code, String name) {this.code code;this.name name;}Overridepublic Integer getValue() {return code;}public String getName() {return name;}}
JsonFormat 注解为了解决枚举类返回前端只展示构造器名称的问题。
2. 实体类性别字段
TableName(value \user\)
public class UserDO {/*** 主键*/TableId(value \id\, type IdType.AUTO)private Long id;/*** 昵称*/TableField(value \nickname\,condition SqlCondition.EQUAL)private String nickname;/*** 性别*/TableField(value \sex\)private SexEnum sex;/*** 版本*/TableField(value \version\,update \%s1\)private Integer version;/*** 时间字段自动添加*/TableField(value \create_time\,fill FieldFill.INSERT)private LocalDateTime createTime;
}
3. 配置文件扫描枚举
mybatis-plus:# 支持统配符 * 或者 ; 分割typeEnumsPackage: com.wjbgn.*.enums
4. 定义配置文件
Bean
public MybatisPlusPropertiesCustomizer mybatisPlusPropertiesCustomizer() {return properties - {GlobalConfig globalConfig properties.getGlobalConfig();globalConfig.setBanner(false);MybatisConfiguration configuration new MybatisConfiguration();configuration.setDefaultEnumTypeHandler(MybatisEnumTypeHandler.class);properties.setConfiguration(configuration);};
}
5. 序列化枚举值为数据库值
以下我是使用的 fastjson
全局添加在前面的配置文件中 Beanpublic MybatisPlusPropertiesCustomizer mybatisPlusPropertiesCustomizer() {// 序列化枚举值为数据库存储值FastJsonConfig config new FastJsonConfig();config.setSerializerFeatures(SerializerFeature.WriteEnumUsingToString);return properties - {GlobalConfig globalConfig properties.getGlobalConfig();globalConfig.setBanner(false);MybatisConfiguration configuration new MybatisConfiguration();configuration.setDefaultEnumTypeHandler(MybatisEnumTypeHandler.class);properties.setConfiguration(configuration);};}
局部 JSONField(serialzeFeatures SerializerFeature.WriteEnumUsingToString)private SexEnum sex;
2.6 自动填充 还记得前面提到的实体类当中的注解TableFeild吗当中有个属性叫做 fill通过FieldFill设置属性这个就是做自动填充用的。
public enum FieldFill {/*** 默认不处理*/DEFAULT,/*** 插入填充字段*/INSERT,/*** 更新填充字段*/UPDATE,/*** 插入和更新填充字段*/INSERT_UPDATE
}
但是这个直接是不能使用的需要通过实现 mybatis-plus 提供的接口增加如下配置
/*** description: 启动自动填充功能*/
Component
public class MyMetaObjectHandler implements MetaObjectHandler {Overridepublic void insertFill(MetaObject metaObject) {// 起始版本 3.3.0(推荐使用)this.strictInsertFill(metaObject, \createTime\, LocalDateTime.class, LocalDateTime.now());}Overridepublic void updateFill(MetaObject metaObject) {// 起始版本 3.3.0(推荐)this.strictUpdateFill(metaObject, \updateTime\, LocalDateTime.class, LocalDateTime.now());}
}
字段如下
/*** 时间字段自动添加*/
TableField(value \create_time\,fill FieldFill.INSERT)
private LocalDateTime createTime;
2.7 多数据源
前面提到过配置文件当中配置了主从的方式其实 mybatis-plus 还支持更多的方式
·多主多从
spring:datasource:dynamic:primary: master #设置默认的数据源或者数据源组,默认值即为masterstrict: false #严格匹配数据源,默认false. true未匹配到指定数据源时抛异常,false使用默认数据源datasource:master_1:master_2:slave_1:slave_2:slave_3:
·多种数据库
spring:datasource:dynamic:primary: mysql #设置默认的数据源或者数据源组,默认值即为masterstrict: false #严格匹配数据源,默认false. true未匹配到指定数据源时抛异常,false使用默认数据源datasource:mysql:oracle:postgresql:h2:sqlserver:
·混合配置
spring:datasource:dynamic:primary: master #设置默认的数据源或者数据源组,默认值即为masterstrict: false #严格匹配数据源,默认false. true未匹配到指定数据源时抛异常,false使用默认数据源datasource:master_1:slave_1:slave_2:oracle_1:oracle_2:
上面的三种方式除了混合配置我觉得都有肯能出现的吧。
DS 注解
可以注解在方法上或类上同时存在就近原则 【方法上注解】 优先于 【类上注解】
DS(\slave_1\)
public class UserServiceImpl extends ServiceImplUserMapper, UserDO implements IUserService {DS(\salve_1\)Overridepublic ListUserDO getList() {return this.getList();}DS(\master\)Overridepublic int saveUser(UserDO userDO) {boolean save this.save(userDO);if (save){return 1;}else{return 0;}}
}
3 测试
经过上面的配置下面开始进入测试验证阶段。
建立一张表
CREATE TABLE user (id int(11) NOT NULL AUTO_INCREMENT,nickname varchar(255) NOT NULL COMMENT 昵称,sex tinyint(1) NOT NULL COMMENT 性别1男2女,create_time datetime NOT NULL COMMENT 创建时间,is_delete tinyint(1) NOT NULL DEFAULT 0 COMMENT 是否删除 1是0否,PRIMARY KEY (id)
) ENGINEInnoDB AUTO_INCREMENT50 DEFAULT CHARSETutf8mb4;
controller
/*** description 用户controller* version3.0*/
RestController
RequestMapping(\/user\)
public class UserController {Autowiredprivate IUserService userService;/*** description: 新增* return: boolean*/RequestMapping(\/save\)public boolean save() {UserDO userDO new UserDO();userDO.setNickname(\大漂亮\);userDO.setSex(SexEnum.MAN);return userService.save(userDO);}/*** description: 修改* param nickname* param id* return: boolean*/RequestMapping(\/update\)public boolean update(RequestParam String nickname,RequestParam Long id) {UserDO userDO new UserDO();userDO.setNickname(nickname);userDO.setId(id);return userService.updateById(userDO);}/*** description: 删除* param id* return: boolean*/RequestMapping(\/delete\)public boolean delete(RequestParam Long id) {UserDO userDO new UserDO();userDO.setId(id);return userService.removeById(userDO);}/*** description: 列表* return: java.util.Listcom.wjbgn.user.entity.UserDO*/RequestMapping(\/list\)public ListUserDO list() {return userService.list();}/*** description: 分页列表* param current* param size* return: com.baomidou.mybatisplus.extension.plugins.pagination.Page*/RequestMapping(\/page\)public Page page(RequestParam int current,RequestParam int size) {return userService.page(new Page(current,size), new QueryWrapper(new UserDO()));}} 经过上面的接口验证功能没有问题集成成功。上文基本覆盖了 mybatis-plus 常用的特性有同学说自动代码生成没说