mybatis-plus全局Update更新策略,和insert插入查询策略

mybatis-plus全局Update更新策略,和insert插入查询策略
从官方文档可知,数据库全局配置策略有三种,分别是查询策略,更新策略,和添加策略

他们的属性:

IGNORED 忽略判断,所有字段都进行更新和插入
NOT_NULL只更新和插入非NULL值
NOT_EMPTY 只更新和插入非NULL值且非空字符串
NEVER 永远不进行更新和插入
DEFAULT 默认NOT_NULL —>只更新和插入非NULL值

package com.java1234.entity;

import com.baomidou.mybatisplus.annotation.FieldStrategy;
import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import lombok.Data;

import java.math.BigDecimal;
import java.util.Date;
import java.util.List;

/**
 * 商品
 * @author java1234_小锋
 * @site www.java1234.com
 * @company 南通小锋网络科技有限公司
 * @create 2021-11-22 22:13
 */
@TableName("t_product")
@Data
public class Product {

    private Integer id; // 编号

    private String name; // 名称

    private BigDecimal price; // 价格

    private String productIntroImgs; // 商品介绍图片

    private String productParaImgs;  // 商品规格参数图片

    private Integer stock; // 库存

    private String proPic="default.jpg"; // 商品图片

    private boolean isHot=false; // 是否热门推荐商品

    private boolean isSwiper=false; // 是否轮播图片商品

    private Integer swiperSort=0; // 轮播排序

    private String swiperPic="default.jpg"; // 商品轮播图片

    private String description; // 描述

    @JsonSerialize(using=CustomDateTimeSerializer.class)
    @TableField(updateStrategy = FieldStrategy.IGNORED)
    private Date hotDateTime; // 设置热门推荐日期时间

    @TableField(select = false)
    private List<ProductSwiperImage> productSwiperImageList;

    @TableField(select = false)
    private SmallType type; //商品类别
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MyBatis-Plus 中,可以通过自定义全局配置的方式来进行时间格式化。具体步骤如下: 1.创建一个类,并实现 `MetaObjectHandler` 接口。 ```java @Component public class MyMetaObjectHandler implements MetaObjectHandler { @Override public void insertFill(MetaObject metaObject) { // 插入时自动填充 createTime 和 updateTime 字段的值 this.setFieldValByName("createTime", LocalDateTime.now(), metaObject); this.setFieldValByName("updateTime", LocalDateTime.now(), metaObject); } @Override public void updateFill(MetaObject metaObject) { // 更新时自动更新 updateTime 字段的值 this.setFieldValByName("updateTime", LocalDateTime.now(), metaObject); } } ``` 2.在 `application.yml` 文件中配置 MyBatis-Plus全局配置。 ```yaml mybatis-plus: global-config: db-config: logic-delete-value: 1 logic-not-delete-value: 0 id-type: auto meta-object-handler: com.example.MyMetaObjectHandler sql-injector: com.baomidou.mybatisplus.core.injector.LogicSqlInjector # 时间字段格式化 date-format: yyyy-MM-dd HH:mm:ss ``` 在配置文件中,通过 `date-format` 属性来设置时间字段的格式化方式。这里以 yyyy-MM-dd HH:mm:ss 为例。 3.在实体类中,对需要格式化的时间字段进行注解。 ```java @Data public class User { @TableId(type = IdType.AUTO) private Long id; private String name; private Integer age; private LocalDateTime createTime; private LocalDateTime updateTime; // 注解时间字段,告诉 MyBatis-Plus 要进行格式化 @TableField(fill = FieldFill.INSERT) @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss") private LocalDateTime createTime; // 注解时间字段,告诉 MyBatis-Plus 要进行格式化 @TableField(fill = FieldFill.UPDATE) @JsonFormat(shape = JsonFormat.Shape.STRING, pattern = "yyyy-MM-dd HH:mm:ss") private LocalDateTime updateTime; } ``` 在实体类中,通过 `@TableField` 注解来告诉 MyBatis-Plus 要对该字段进行格式化,同时,也可以使用 `@JsonFormat` 注解来指定时间格式化的方式。 以上就是 MyBatis-Plus 全局配置时间格式化的步骤。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值