java mybatis 乐观锁,Mybatis-plus学习(六)——MybatiPlus的乐观锁和自动填充功能详解...

7.乐观锁

7.1OptimisticLockerInnerInterceptor

当要更新一条记录的时候,希望这条记录没有被别人更新

乐观锁实现方式:

取出记录时,获取当前version

更新时,带上这个version

执行更新时, set version = newVersion where version = oldVersion

如果version不对,就更新失败

7.2使用方法

字段上加上@Version注解

@Version

private Integer version;

说明:

支持的数据类型只有:int,Integer,long,Long,Date,Timestamp,LocalDateTime

整数类型下 newVersion = oldVersion + 1

newVersion 会回写到 entity 中

仅支持 updateById(id) 与 update(entity, wrapper) 方法

在 update(entity, wrapper) 方法下, wrapper 不能复用!!!

8.自动填充功能

8.1原理

①实现元对象处理器接口:com.baomidou.mybatisplus.core.handlers.MetaObjectHandler

②注解填充字段 @TableField(.. fill = FieldFill.INSERT) 生成器策略部分也可以配置!

public class User {

// 注意!这里需要标记为填充字段

@TableField(.. fill = FieldFill.INSERT)

private String fillField;

....

}

③自定义实现类 MyMetaObjectHandler

@Slf4j

@Component

public class MyMetaObjectHandler implements MetaObjectHandler {

@Override

public void insertFill(MetaObject metaObject) {

log.info("start insert fill ....");

this.strictInsertFill(metaObject, "createTime", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推荐使用)

// 或者

this.strictUpdateFill(metaObject, "createTime", () -> LocalDateTime.now(), LocalDateTime.class); // 起始版本 3.3.3(推荐)

// 或者

this.fillStrategy(metaObject, "createTime", LocalDateTime.now()); // 也可以使用(3.3.0 该方法有bug)

}

@Override

public void updateFill(MetaObject metaObject) {

log.info("start update fill ....");

this.strictUpdateFill(metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now()); // 起始版本 3.3.0(推荐)

// 或者

this.strictUpdateFill(metaObject, "updateTime", () -> LocalDateTime.now(), LocalDateTime.class); // 起始版本 3.3.3(推荐)

// 或者

this.fillStrategy(metaObject, "updateTime", LocalDateTime.now()); // 也可以使用(3.3.0 该方法有bug)

}

}

注意事项:

填充原理是直接给entity的属性设置值!!!

注解则是指定该属性在对应情况下必有值,如果无值则入库会是null

MetaObjectHandler提供的默认方法的策略均为:如果属性有值则不覆盖,如果填充值为null则不填充

字段必须声明TableField注解,属性fill选择对应策略,该声明告知Mybatis-Plus需要预留注入SQL字段

填充处理器MyMetaObjectHandler在 Spring Boot 中需要声明@Component或@Bean注入

要想根据注解FieldFill.xxx和字段名以及字段类型来区分必须使用父类的strictInsertFill或者strictUpdateFill方法

不需要根据任何来区分可以使用父类的fillStrategy方法

public enum FieldFill {

/**

* 默认不处理

*/

DEFAULT,

/**

* 插入填充字段

*/

INSERT,

/**

* 更新填充字段

*/

UPDATE,

/**

* 插入和更新填充字段

*/

INSERT_UPDATE

}

8.2在springboot中实现

8.2.1首先在account表中添加createTime和updateTime字段

f55fbc980abdbec746a2273a2d4cd4f8.png

8.2.2在Account.java中添加字段以及注释

//插入时自动生成

@TableField(fill = FieldFill.INSERT)

private LocalDateTime createTime;

//更新时自动生成

@TableField(fill = FieldFill.INSERT_UPDATE)

private LocalDateTime updateTime;

8.2.3在Component包中新建一个类AccountMetaHandler.java

package com.moyisuiying.booksystem.component;

import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;

import lombok.extern.slf4j.Slf4j;

import org.apache.ibatis.reflection.MetaObject;

import org.springframework.stereotype.Component;

import java.time.LocalDateTime;

/**

* Classname:AccountMetaHandler

*

* @description:

* @author: 陌意随影

* @Date: 2020-11-25 22:56

* @Version: 1.0

**/

@Component

@Slf4j

public class AccountMetaHandler implements MetaObjectHandler {

@Override

public void insertFill(MetaObject metaObject) {

log.info("start insert fill ....");

// 起始版本 3.3.0(推荐使用)

this.strictInsertFill(metaObject, "createTime", LocalDateTime.class, LocalDateTime.now());

}

@Override

public void updateFill(MetaObject metaObject) {

log.info("start update fill ....");

// 起始版本 3.3.0(推荐使用)

this.strictUpdateFill(metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now());

}

}

8.3测试插入和更新操作

@Test

public void testInsert(){

Account account = new Account();

account.setName("硝酸钠");

account.setPassword("ab");

int fla = accountDao.insert(account);

System.out.println(fla);

}

@Test

public void testUpdate(){

Account account = new Account();

account.setId(27);

account.setName("李四");

account.setPassword("aaaaa");

int update = accountDao.updateById(account);

System.out.println(update);

}

经过测试可以发现createTime在插入记录时会自动填充数据库中createTime的值;当update更新操作时updateTime会被自动更新。

a60fba28833e9c0046c6a5b823d70c00.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值