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 Model<Customer> {
private static final long serialVersionUID = 1L;
/**
* 主键ID
*/
@TableId(value = "id", type = IdType.AUTO)
private Long id;
/**
* 客户公司名
*/
@TableField(value = "name")
private String name;
/**
* 租户id