zl程序教程

您现在的位置是:首页 >  其他

当前栏目

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;
mybatis

自动给空字段添加默认值

MetaObjectHandler介绍

  1. 编写MetaObjectHandler 实现类
  2. 实体类上边加上@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);