物理删除与逻辑删除

这篇具有很好参考价值的文章主要介绍了物理删除与逻辑删除。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

一、物理删除与逻辑删除

二、逻辑删除实现

三、API使用方法

 四、全局配置参数


一、物理删除与逻辑删除

  • 物理删除:指文件存储所用到的磁存储区域被真正的擦除或清零,这样删除的文件是不可以恢复的,物理删除是计算机处理数据时的一个概念。如果在数据库中直接使用delete、drop删除了表数据,如果没有备份的话,数据就很难恢复了。
  • 逻辑删除(软删除):逻辑删除就是对要被删除的数据打上一个删除标记,通常使用一个deleted字段标示行记录是不是被删除,比如该数据有一个字段deleted,当其值为0表示未删除,值为1表示删除。那么逻辑删除就是将0变成1。在逻辑上是数据是被删除的,但数据本身是依然存在的。

两者的优劣:

  • 物理删除一定程度上删除了“无用”的数据,降低了表的数据量,对性能肯定是有好处的;但是如果没有备份的话,数据很难恢复。也无法对历史数据进行数据分析。
  • 逻辑删除恢复的话只要修改ideleted等类似的状态标示字段就可以了,但是表的数据量肯定会比物理删除增加了,并且查询时经常要考虑到deleted字段,对索引都会有影响。

所以一张表的数据是否采用逻辑删除,还要根据数据的重要性、数据量、查询性能以及业务需求等因素综合判断。

二、逻辑删除实现

  • 首先为需要逻辑删除的表增加一个deleted字段作为逻辑删除字段,并且设置其默认值为0,如下:
CREATE TABLE `user` (
	`id` BIGINT(20) NOT NULL COMMENT '主键ID',
	`name` VARCHAR(30) NULL DEFAULT NULL COMMENT '姓名',
	`age` INT(11) NULL DEFAULT NULL COMMENT '年龄',
	`email` VARCHAR(50) NULL DEFAULT NULL COMMENT '邮箱',
	`deleted` TINYINT(4) NOT NULL DEFAULT '0' COMMENT '逻辑删除标记',
	PRIMARY KEY (`id`)
);
  • 给数据库表对应的实体类字段上加上@TableLogic注解:

另外解释一下@TableLogic这个注解。

@TableLogic注解是逻辑删除,并不会永久删除数据,实体类加上这个注解再执行删除方法的时候会变成修改。前台再根据所加注解字段进行显隐即可达到逻辑删除效果。

@TableLogic(value=“原值”,delval=“修改值”)
注解参数
    value = “” 未删除的值,默认值为0
    delval = “” 删除后的值,默认值为1


使用方法:
在实体类属性上加@TableLogic(value=“0”,delval=“1”)

	@TableLogic(value="0",delval="1")
    private String isdelete;

 

物理删除与逻辑删除

 

三、API使用方法

3.1.插入一条数据

插入数据的时候,不需要为deleted字段赋值.

@Test
public void testInsert() {
  User user = new User();
  user.setName("***");
  user.setAge(19);

  int row = userMapper.insert(user);
}

deleted采用默认值0(未删除),新插入的数据都是未删除的数据.

3.2.删除一条记录:

执行如下Mybatis Plus API删除操作

userMapper.deleteById(***);

 查看数据库时这条数据仍然存在,只不过逻辑删除字段值被设置为1:

UPDATE user SET deleted=1 WHERE id=? AND deleted=0

3.3.查询一条记录

  • 当我们使用MP逻辑删除的功能之后,比如执行查询、修改的方法,MP会为我们自动加上未删除的条件。
    是不会查到被逻辑删除的记录:
userMapper.selectList(null);

会自动添加过滤条件  WHERE deleted=0

SELECT id,name,age,email,deleted
FROM user 
WHERE deleted=0 
  • 当我们查询数据时,查询结果不希望包含逻辑删除字段,可以加如下的注解
@TableLogic
@TableField(select = false)
private Integer deleted;

执行的SQL如下(注意查询结果不包含deleted字段):

SELECT id,name,age,email 
FROM user 
WHERE deleted=0

 四、全局配置参数

通常在一个比较正规的管理项目中,逻辑删除字段不允许随意命名,所有表的逻辑删除字段使用相同的名称(比如:deleted)。我们可以在application.yml中添加全局配置,这样就不需要在每一个实体类上面都添加 @TableLogic注解了:

注意:当全局配置和@TableLogic局部配置同时存在,则以实体上注解为准,优先级更高。

#全局逻辑删除字段值
mybatis-plus:
  global-config:
    db-config:
      logic-delete-field: deleted

默认情况下,逻辑已删除值为1,逻辑未删除值为0。我们也可以在application.yml中进行修改:文章来源地址https://www.toymoban.com/news/detail-460345.html

#逻辑已删除值(默认为 1)
#逻辑未删除值(默认为 0)
mybatis-plus:
  global-config:
    db-config:
      logic-delete-value: 1
      logic-not-delete-value: 0

到了这里,关于物理删除与逻辑删除的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包