MybatisPlus中@TableLogic 逻辑删除 的使用

@TableLogic 注解的用法,以及每个属性的实际意义和用法

1、注解说明

@TableLogic 用于实现数据库数据逻辑删除
注意,该注解只对自动注入的 sql 起效

2、@TableLogic 对于 CRUD 的限制

2.1 插入(insert)
                   不作限制
2.2 查找(select)
           @TableLogic 注解将会在 select 语句的 where 条件添加条件,过滤掉已删除数据
           且使用 wrapper.entity 生成的 where 条件会忽略该字段
           SELECT user_id,name,sex,age,deleted FROM user WHERE user_id=1 AND deleted='0'

2.3 更新(update)
         @TableLogic 注解将会在 update 语句的 where 条件后追加条件,防止更新到已删除数据
         且使用 wrapper.entity 生成的 where条件会忽略该字段
         update user set deleted=1 where id = 1 and deleted=0
2.4 删除(delete)
        @TableLogic 注解会将 delete 语句转变为 update 语句
        update user set deleted=1 where id = 1 and deleted=0
3、@TableLogic 字段类型支持说明:

支持所有数据类型(推荐使用 Integer、Boolean、LocalDateTime)
如果数据库字段使用 datetime,逻辑未删除值和已删除值支持配置为字符串 null,另一个值支持配置为函数来获取值如now()
附录:
(1)逻辑删除是为了方便数据恢复和保护数据本身价值等等的一种方案,但实际就是删除。
(2)如果你需要频繁查出来看就不应使用逻辑删除,而是以一个状态去表示。

  1. 属性说明
    3.1 value
    用来指定逻辑未删除值,默认为空字符串

3.2 delval
用来指定逻辑删除值,默认为空字符串。
6. 在配置文件中实现
当然,你也可以不在 @TableLogic 注解中指定 value 和 delval 属性的值。使用全局逻辑删除配置信息,配置如下:

# application.yml

mybatis-plus:
  global-config:
    db-config:
全局逻辑删除的实体字段名 (since 3.3.0, 配置后可以忽略 @TableLogic 中的配置)

​      logic-delete-field: flag

      # 逻辑已删除值(默认为 1)

​      logic-delete-value: 1

      # 逻辑未删除值(默认为 0)

​      logic-not-delete-value: 0
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值