MyBatis-Plus踩坑记录
2023-04-18 14:53:44 时间
最近写个小项目要用到mybatis plus,有些不太清楚的点,查了下官方文档,顺便做下简要的记录,下面是笔记。
官方文档地址:
https://mp.baomidou.com/guide/quick-start.html
主键规则
- AUTO(0), 自增
- NONE(1),
- INPUT(2), 手动输入
- ID_WORKER(3), 雪花id
- UUID(4), UUID
- ID_WORKER_STR(5);
/**
* id 手机号
* 主键插入方式,手动
*/
@TableId(value = "user_mobile", type = IdType.INPUT)
@ApiModelProperty(value = "id 手机号")
@JsonIgnore
private String userMobile;
自动给空字段添加默认值
MetaObjectHandler介绍
- 编写MetaObjectHandler 实现类
- 实体类上边加上@TableField(fill = FieldFill.INSERT_UPDATE)
MetaObjectHandler介绍
MetaObjectHandler接口是mybatisPlus为我们提供的的一个扩展接口,我们可以利用这个接口在我们插入或者更新数据的时候,为一些字段指定默认值。实现这个需求的方法不止一种,在sql层面也可以做到,在建表的时候也可以指定默认值。
1:编写MetaObjectHandler 实现类
编写类实现MetaObjectHandler接口,重写里面的方法就是了。
/**
* @author 张子行
* @class mybatisPlus属性自动填充,对应的实体类字段上需要加@TableField(fill = FieldFill.INSERT_UPDATE)
*/
@Configuration
@Slf4j
public class autoFillConfig implements MetaObjectHandler {
/**
* @param
* @method 插入时自动填充
*/
@Override
public void insertFill(MetaObject metaObject) {
log.info("插入时自动填充");
this.setFieldValByName("stock", 1, metaObject);
}
/**
* @param
* @method 更新时自动填充
*/
@Override
public void updateFill(MetaObject metaObject) {
log.info("更新时自动填充");
this.setFieldValByName("stock", -9090, metaObject);
}
}
2:实体类上边加上@TableField
参数介绍:
- DEFAULT,
- INSERT,
- UPDATE,
- INSERT_UPDATE;
指定进行属性填充的时机(更新、插入、或者更新和插入)
@TableField(fill = FieldFill.INSERT_UPDATE)
@ApiModelProperty(value = "商品库存")
private Integer stock;
特殊情况
mybatisPlus指定字段更新,其他字段不会更新
UpdateWrapper<Goods> goodsUpdateWrapper = new UpdateWrapper<>();
goodsUpdateWrapper.eq("id", 30).set("name", "张子行666");
goodsService.update(null, goodsUpdateWrapper);
这种情况会进行属性填充,指定了实体类
Goods goods = new Goods();
goods.setId(30).setName("zzh").setPrice(100D).setRemark("张子行5").setGoodsTypeId(666).setStock(10);
goodsUpdateWrapper.eq("id", 30).set("name", "张子行666");
goodsService.update(goods, goodsUpdateWrapper);
相关文章
- 【技术种草】cdn+轻量服务器+hugo=让博客“云原生”一下
- CLB运维&运营最佳实践 ---访问日志大洞察
- vnc方式登陆服务器
- 轻松学排序算法:眼睛直观感受几种常用排序算法
- 十二个经典的大数据项目
- 为什么使用 CDN 内容分发网络?
- 大数据——大数据默认端口号列表
- Weld 1.1.5.Final,JSR-299 的框架
- JavaFX 2012:彻底开源
- 提升as3程序性能的十大要点
- 通过凸面几何学进行独立于边际的在线多类学习
- 利用行动影响的规律性和部分已知的模型进行离线强化学习
- ModelLight:基于模型的交通信号控制的元强化学习
- 浅谈Visual Source Safe项目分支
- 基于先验知识的递归卡尔曼滤波的代理人联合状态和输入估计
- 结合网络结构和非线性恢复来提高声誉评估的性能
- 最佳实践丨云开发CloudBase多环境管理实践
- TimeVAE:用于生成多变量时间序列的变异自动编码器
- 具有线性阈值激活的神经网络:结构和算法
- 内网渗透之横向移动 -- 从域外向域内进行密码喷洒攻击