Java反射获取及创建class的方法和mybatis-plus的逻辑删除配置

本文介绍了Java反射获取及创建class的方法,并详细阐述了mybatis-plus的逻辑删除配置,包括@TableField和@TableLogic注解的使用,以及如何通过注解简化对象创建。此外,还列举了获取方法的三种方式和类创建的两种方法。

Java反射获取及创建class的方法和mybatis-plus的逻辑删除配置

mybatis-plus的逻辑删除配置

Customer类
@AllArgsConstructor 注解表示所有参数的构造函数
@NoArgsConstructor 注解表示无参构造函数
@Accessors(chain = true) 注解表示可以直接通过对象的变量名.属性的方式去设置或获取值。

 /**
     * 更新客户
     *
     * @return
     */
    private Boolean updateCustomer(Customer entity) {
        entity.setUpdateUser(ShiroUtil.getUserId()).setUpdateTime(LocalDateTime.now());
        return this.updateById(entity);
    }

如果使用了@Builder注解,则@Accessors(chain = true)注解可以删除
该注解用法如下,主要用于减少new对象,直接用对象.builder().属性.属性.build()去设置参数

 if (CheckUtil.notEmpty(beforeData) && CheckUtil.notEmpty(afterData)) {
            HandleLogDTO logDTO = HandleLogDTO.builder().type(handleType).device(dto.getDevice()).orderId(dto.getId()).
                    orderNumber(dto.getOrderNumber()).beforeData(beforeData).afterData(afterData).createUser(ShiroUtil.getUserId()).createTime(LocalDateTime.now()).build();
            HandleLog entity = mapperFacade.map(logDTO, HandleLog.class);
            integer = mapper.saveHandleLog(entity);
        }

@TableField 注解的value = "create_user"对应数据该字段名, fill = FieldFill.INSERT表示该字段何时自动填充,
主要有三种方式:FieldFill.INSERT,FieldFill.UPDATE,INSERT_UPDATE,分别表示新增,修改,新增和修改时自动填充值。

@TableLogic
@TableField(value = "del_flag",fill = FieldFill.INSERT)
private Integer delFlag;

这个delFlag字段上加的@TableLogic注解表示是逻辑删除,当调用service的removeById(T entity)或者调用mapper的deleteById(T entity)删除数据时,通过该配置和@TableField(value = “del_flag”,fill = FieldFill.INSERT)及yaml配置文件中指定的默认值,会自动更新该字段,不需要先设置再删除。这样在多次要调用删除方法时就可以少写一些重复的代码了。
在这里插入图片描述

@Data
@EqualsAndHashCode(callSuper = true)
@Accessors(chain = true)
@AllArgsConstructor
@NoArgsConstructor
@TableName("os_customer")
public class Customer extends Mode
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值