mybatis-plus使用心得
mybatis-plus是一款基于mybatis的持久层框架,在mybatis上只做增强不做改变。基本使用流程:
- 导入依赖坐标:
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>Latest Version</version>
</dependency> - 在yml文件中配置使用的数据源。
- mybatisplus分别在dao层和service层提供了基础的接口,提供了基础的增删改查实现。只需要继承BaseMapper和Iservice接口。
- 在mybatis-plus中集成了分页插件,需要在配置类中将插件配置成bean加入容器中。
@Bean
public MybatisPlusInterceptor mybatisPlusInterceptor(){
MybatisPlusInterceptor mybatisPlusInterceptor = new MybatisPlusInterceptor();
mybatisPlusInterceptor.addInnerInterceptor(new PaginationInnerInterceptor(DbType.MYSQL));
return mybatisPlusInterceptor;
} - 集成日志配置,在yml文件中配置:
mybatis-plus:
configuration:
log-impl: org.apache.ibatis.logging.stdout.StdOutImpl - id生成:mybatis-plus自带主键生成策略,使用注解
@TableId(type = IdType.AUTO)
private Long id; - 自动填充,一般数据库中都有修改时间,新增时间等字段,mybatis-plus可以通过配置生成策略自动生成。代码中在实体类上需要自动填充的字段使用注解标注。
@TableField(value = "gmt_create",fill = FieldFill.INSERT)
private Date gmtCreate; @TableField(value = "gmt_modified",fill = FieldFill.INSERT_UPDATE)
private Date gmtModified;需要将自动填充策略作为bean添加到容器中,自定义填充字段的生成策略。
@Slf4j
@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
log.info("start insert fill....");
this.setFieldValByName("gmtCreate",new Date(),metaObject);
this.setFieldValByName("gmtModified",new Date(),metaObject);
} @Override
public void updateFill(MetaObject metaObject) {
log.info("start update fill....");
this.setFieldValByName("gmtModified",new Date(),metaObject);
}
} - 逻辑删除字段处理,实际开发中数据库的字段一般不会进行物理删除,通常使用逻辑删除修改标记位。mybatis-plus中使用注解@Tablelogic实现,数据库增加逻辑删除字段,实体类上标注
@TableLogic(value = "1",delval = "0") //逻辑删除
private Integer deleted;在yml文件中指明逻辑删除标记位:
mybatis-plus:
global-config:
db-config:
logic-delete-field: deleted # 逻辑删除的字段
logic-delete-value: 1 # 1代表删除
logic-not-delete-value: 0 # 0代表未删除 - 乐观锁/悲观锁 mybatis-plus中使用@Version字段实现乐观锁,数据库添加version字段,实体类处理:
@Version
private Integer version;将乐观锁组件注册到IOC中
@Bean
public OptimisticLockerInnerInterceptor optimisticLockerInnerInterceptor(){
return new OptimisticLockerInnerInterceptor();
} - mybatis-plus处理枚举字段,使用自定义的枚举类表示,可以使用@EnumValue注解加在要保存进数据库中的字段上,mp将会自动映射。使用@JsonValue加在枚举类中要返回给前端的属性的get方法上,返回时将会自动映射,如SexEnum中返回前端的就是(“男人”/“女人”).
public enum SexEnum {
MAN(1, "男人"),
WOMAN(0, "女人"); @EnumValue
private int code; private String value; SexEnum(int code, String value) {
this.code = code;
this.value = value;
} public int getCode() {
return code;
} @JsonValue
public String getValue() {
return value;
}
}yml文件中配置
mybatis-plus:
type-enums-package: com.codeyoung.json.domain # 指定枚举类所在的包
configuration:
default-enum-type-handler: org.apache.ibatis.type.EnumOrdinalTypeHandler # 指定默认枚举类处理器 - mybatis-plus处理json字段的数据,如果数据库中字段为json格式的字符串,可以使用@TableFiled(Typehandler=JacksonTypeHandler.class)实现javatype到jdbctype的互转,可以将实体类对象转为json字符串存入到表中。
@Data
public class Foo {
private Long id;
private String bar;
private Bar barObj;
private Date createTime;
} @Data
public class Bar {
private String name;
private Integer quz;
private Date timestamp;
}
mybatis-plus使用心得的更多相关文章
- mybatis 关联表心得
1,例如订单表与用户表的关联,一个订单对应一个用户,这是一对一关联: 用代码实现是这样: A(用resultType去实现的话,如下) 1,使用到继承, OrderUser extend Order{ ...
- spring mvc&mybatis搭配使用心得
请求参数不多时控制器方法使用@RequestParam或@PathVariable接收参数即可. 请求参数过多时使用@RequestParam指定一个map接受参数即可,mybatis查询时可以直接作 ...
- Echo团队Alpha冲刺随笔 - 第五天
项目冲刺情况 进展 前端:布局,内容等方面基本完成. 后端:基本功能基本实现. 计划:准备进行前后端对接,进行测试 问题 有部分代码冗余,需要着手修改 心得 团队分工明确,互相协作,开发进度比预想的要 ...
- 新建maven工程问题001
这周一直在研究SpringMVC+Mybatis,有些心得,记录一下. Ⅰ:建maven遇到的问题. 1.1 新建maven时选中[Create a simple project]这样,后面[Pack ...
- Java开发学习心得(二):Mybatis和Url路由
目录 Java开发学习心得(二):Mybatis和Url路由 1.3 Mybatis 2 URL路由 2.1 @RequestMapping 2.2 @PathVariable 2.3 不同的请求类型 ...
- 关于mybatis中mapper.xmlSQL语句书写的心得
本文主要针对MySQL ---------------------------------------------------------------------------------------- ...
- MyBatis使用DEMO及cache的使用心得
下面是一个简单的MyBatis使用DEMO. 整体结构 整体代码大致如下: POM依赖 需要引用两个jar包,一个是mybatis,另一个是mysql-connector-java,如果是maven工 ...
- myBatis xml if、where、if-else?、foreach 心得
MyBatis 的强大特性之一便是它的动态 SQL.如果你有使用 JDBC 或其它类似框架的经验,你就能体会到根据不同条件拼接 SQL 语句的痛苦.例如拼接时要确保不能忘记添加必要的空格,还要注意去掉 ...
- 34对MyBatis的博客的整理心得
对本博客的mybatis重新读一下,做一个整理.如下: 1:为什么会有mybatis,因为原生的jdbc方式有很大问题: (1)数据库连接,使用时就创建,不使用立即释放,对数据库进行频繁连接开启和关闭 ...
- mybatis源码阅读心得
第一天阅读源码及创建时序图.(第一次用prosson画时序图,挺丑..) 1. 调用 SqlSessionFactoryBuilder 对象的 build(inputStream) 方法: 2. ...
随机推荐
- == 与 equals 的区别?
一. 介绍: Java中的 "==" 是一个运算符,是用于比较两个对象地址值或基本数据类型之间的值是否相等.它的来源可以追溯到C语言,以及受C语言影响的许多其他编程语言. Jav ...
- mysql怎样实现不重复插入数据
mysql使用用insert往数据表中插入数据时,为了不重复插入数据,往往先查询一下该条数据是否已经存在,若不存在才进行插入操作. 而使用 insert if not exists语句,就不需重复做上 ...
- Nginx TCP 负载均衡:stream 模块配置
工作上遇到需要用nginx做负载均衡,参考了前同事留下的作业顺利搞定,感觉这块很有意义写篇文档记录. 参考:nginx tcp负载均衡(Stream模块)配置说明 参考:利用nginx进行TCP负载均 ...
- .Net Core控制台程序读取Json配置文件
1 添加依赖(可以直接通过nuget包安装 Microsoft.Extensions.Configuration.Json 这个会依赖其他两个会自动安装依赖的) Microsoft.Extension ...
- 来会会babel这个重要且神奇的工具
babel 在前端工程化开发中发挥着至关重要的作用,它能将较高级的语法转成浏览器可识别的代码,无论中 es6 中 const .promise 还是 React.TypeScript. 以下babel ...
- 强化学习 Proximal Policy Optimization (PPO)
参考: 李宏毅老师课件 PPO = Policy Gradient 从 On-policy 到 Off-policy, 再加一些constraint Policy Gradient Basic Con ...
- Python 基础面试第二弹
1. 解释下Python中的面向对象,以及面向对象的三大特点: 在Python中,面向对象编程(Object-Oriented Programming,简称OOP)是一种编程范式,它将数据和操作数据的 ...
- GitHub Actions CI/CD 工作流实战
1. 什么是 GitHub Actions 与 workflow ? GitHub Actions 是 GitHub 提供的一种持续集成(CI)和持续部署(CD)的工具,用于自动化软件开发过程中的各种 ...
- MIT 6.828 Lab实验记录 —— lab1 Booting PC
实验参考信息 MIT 6.828 lab1 讲义地址 MIT 6.828 课程 Schedule MIT 6.828 lab 环境搭建参考 MIT 6.828 lab 工具guide Brennan' ...
- API接口的技术的概念
当今互联网技术的发展越来越快,越来越多的网站和应用程序需要获取外部数据来提供更好的服务和用户体验,这就需要使用API接口.本文将会对API接口的概念.类型以及如何调用API接口进行简要介绍. 一.什么 ...