前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MyBatis-Plus踩坑记录

MyBatis-Plus踩坑记录

原创
作者头像
无敌小菜鸟
修改2021-12-14 09:52:15
1.3K0
修改2021-12-14 09:52:15
举报
文章被收录于专栏:搬砖笔记

最近写个小项目要用到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);
代码语言:txt
复制
/**
* id 手机号
* 主键插入方式,手动
*/
@TableId(value = "user_mobile", type = IdType.INPUT)
@ApiModelProperty(value = "id 手机号")
@JsonIgnore
private String userMobile;
mybatis
mybatis

自动给空字段添加默认值

MetaObjectHandler介绍

  1. 编写MetaObjectHandler 实现类
  2. 实体类上边加上@TableField(fill = FieldFill.INSERT_UPDATE)

MetaObjectHandler介绍

MetaObjectHandler接口是mybatisPlus为我们提供的的一个扩展接口,我们可以利用这个接口在我们插入或者更新数据的时候,为一些字段指定默认值。实现这个需求的方法不止一种,在sql层面也可以做到,在建表的时候也可以指定默认值。

1:编写MetaObjectHandler 实现类

编写类实现MetaObjectHandler接口,重写里面的方法就是了。

代码语言:txt
复制
/**
 * @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;

指定进行属性填充的时机(更新、插入、或者更新和插入)

代码语言:txt
复制
@TableField(fill = FieldFill.INSERT_UPDATE)
@ApiModelProperty(value = "商品库存")
private Integer stock;

特殊情况

mybatisPlus指定字段更新,其他字段不会更新

代码语言:txt
复制
UpdateWrapper<Goods> goodsUpdateWrapper = new UpdateWrapper<>();
goodsUpdateWrapper.eq("id", 30).set("name", "张子行666");
goodsService.update(null, goodsUpdateWrapper);

这种情况会进行属性填充,指定了实体类

代码语言:txt
复制
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);

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 主键规则
  • 自动给空字段添加默认值
    • MetaObjectHandler介绍
      • MetaObjectHandler介绍
        • 1:编写MetaObjectHandler 实现类
          • 2:实体类上边加上@TableField
            • 特殊情况
              • mybatisPlus指定字段更新,其他字段不会更新
                • 这种情况会进行属性填充,指定了实体类
                领券
                问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档