最近写个小项目要用到mybatis plus,有些不太清楚的点,查了下官方文档,顺便做下简要的记录,下面是笔记。
官方文档地址:
https://mp.baomidou.com/guide/quick-start.html
/**
* id 手机号
* 主键插入方式,手动
*/
@TableId(value = "user_mobile", type = IdType.INPUT)
@ApiModelProperty(value = "id 手机号")
@JsonIgnore
private String userMobile;
MetaObjectHandler接口是mybatisPlus为我们提供的的一个扩展接口,我们可以利用这个接口在我们插入或者更新数据的时候,为一些字段指定默认值。实现这个需求的方法不止一种,在sql层面也可以做到,在建表的时候也可以指定默认值。
编写类实现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);
}
}
参数介绍:
指定进行属性填充的时机(更新、插入、或者更新和插入)
@TableField(fill = FieldFill.INSERT_UPDATE)
@ApiModelProperty(value = "商品库存")
private Integer stock;
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);
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。