MybatisPlus逻辑删除

举报
别团等shy哥发育 发表于 2023/02/04 16:42:11 2023/02/04
【摘要】 一、配置 1.1、在application.yml配置文件中:# mybatis-plus配置控制台打印sql语句:mybatis-plus: configuration: log-impl: org.apache.ibatis.logging.stdout.StdOutImpl global-config: db-config: logic-delete-fie...

一、配置

1.1、在application.yml配置文件中:

# mybatis-plus配置控制台打印sql语句:
mybatis-plus:
  configuration:
    log-impl: org.apache.ibatis.logging.stdout.StdOutImpl
  global-config:
    db-config:
      logic-delete-field: logicFlag
      logic-delete-value: 1   #默认是1
      logic-not-delete-value: -1 #默认是0
      id-type: auto

然后在实体类的属性上面加上@TableLogic注解就行

@Data
@TableName("tbl_user")
public class User {

    private Integer id;
    //插入和更新操作都会进行字段填充
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private String name;

    @TableLogic //逻辑删除字段
    private Integer logicFlag;
}

1.2、直接在实体类中指定逻辑删除的值

@Data
@TableName("tbl_user")
public class User {

    private Integer id;
    //插入和更新操作都会进行字段填充
    @TableField(fill = FieldFill.INSERT_UPDATE)
    private String name;

    @TableLogic(value = "1",delval = "-1") //逻辑删除字段
    private Integer logicFlag;
}

二、测试

数据库初始数据
在这里插入图片描述

2.1 逻辑删除

现在逻辑删除id为2的这条数据

   @Test
    public void testLogicDelete(){
          Integer i = userMapper.deleteById(2);
        System.out.println("i="+i);
    }

在这里插入图片描述
可以看到,控制台输出的sql语句是更新,而不是删除。会将logic_flag字段设置成-1(-1是我们在application.yml或者@TableLogic注解中指定的值)

2.2 查询逻辑删除的数据

这时查询id为2的这条数据(被逻辑删除的数据)

   @Test
    public void testLogicDelete(){
        User user = userMapper.selectById(2);
        System.out.println(user);
    }

在这里插入图片描述
在这里插入图片描述
可以看到,控制台输出的sql语句自动带上了logic_flag=1的条件,所以查询出来的结果为空,但是数据库中的数据是真实存在的。

【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。