前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >MybatisPlus逻辑删除

MybatisPlus逻辑删除

作者头像
别团等shy哥发育
发布2023-02-25 16:07:06
4640
发布2023-02-25 16:07:06
举报
文章被收录于专栏:全栈开发那些事

文章目录

一、配置

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

代码语言:javascript
复制
# 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注解就行

代码语言:javascript
复制
@Data
@TableName("tbl_user")
public class User {

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

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

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

代码语言:javascript
复制
@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的这条数据

代码语言:javascript
复制
   @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的这条数据(被逻辑删除的数据)

代码语言:javascript
复制
   @Test
    public void testLogicDelete(){
        User user = userMapper.selectById(2);
        System.out.println(user);
    }
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-04-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 文章目录
  • 一、配置
    • 1.1、在application.yml配置文件中:
      • 1.2、直接在实体类中指定逻辑删除的值
      • 二、测试
        • 2.1 逻辑删除
          • 2.2 查询逻辑删除的数据
          相关产品与服务
          数据库
          云数据库为企业提供了完善的关系型数据库、非关系型数据库、分析型数据库和数据库生态工具。您可以通过产品选择和组合搭建,轻松实现高可靠、高可用性、高性能等数据库需求。云数据库服务也可大幅减少您的运维工作量,更专注于业务发展,让企业一站式享受数据上云及分布式架构的技术红利!
          领券
          问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档