实际开发中,数据删除一般有2种选择:
1:物理删除
物理删除,也称为硬删除,指的是数据直接从数据库中移除,对应的SQL语句:DELETE FROM 表 where 条件,这种删除成功后,数据就无法再恢复啦。
2:逻辑删除
逻辑删除,也称为软删除,数据并没有真正删除,而是通过设置数据状态是否可显示,后续查询进行状态过滤,从而隐藏数据显示以达到删除对应的效果。比如:设置is_delete 数据状态, 0表示正常, 1表示删除。 后续的查询sql 加上 where is_delete = 0 就可以过滤删除的数据。
一般开发选用的是逻辑删除,原因有2方面,一是项目数据非常重要不能随意删除,一是项目运行产生数据一般不会是独立,它可能会通过外键形式与其他数据产生关联,如果贸然删除该数据会引起系统不稳定,甚至异常。
举个例子:比如一个用户注册之后,进行发帖,留言,点评,收藏点赞等一些操作,会在系统相关表留下该用户相关信息,如果用户销户,使用物理删除方式删除该用户数据,那么之前与用户产生关联数据表都出现脏数据啦,这很可能导致系统bug。
相关演示表数据 is_delete 0代表未删除 is_delete 1表示已删除
演示只用了员工表 部门表不创建也行
实体类和对应mapper
测试
上面操作属于局部逻辑删除,针对是Em对象,如果其他表也需要逻辑删除怎办?可以全局逻辑删除
配置
全局逻辑删除的实体字段名(since 3.3.0,配置后可以忽略不配置步骤2)
mybatis-plus.global-config.db-config.logic-delete-field=del
逻辑已删除值(默认为 1)
mybatis-plus.global-config.db-config.logic-delete-value=0
逻辑未删除值(默认为 0)
mybatis-plus.global-config.db-config.logic-not-delete-value=1
如果是yml
mybatis-plus:
global-config:
db-config:
logic-delete-field: del # 全局逻辑删除的实体字段名(since 3.3.0,配置后可以忽略不配置步骤2)
logic-delete-value: 1 # 逻辑已删除值(默认为 1)
logic-not-delete-value: 0 # 逻辑未删除值(默认为 0)
版权归原作者 biubiubiu0706 所有, 如有侵权,请联系我们删除。