课次26:自动填充 & 逻辑删除
一、教学目标
配置自动填充(createTime, updateTime)。
验证逻辑删除功能。
二、核心知识点(简要)
MetaObjectHandler:字段自动填充处理器。
@TableField(fill):指定填充时机(INSERT, UPDATE等)。
逻辑删除:UPDATE deleted字段代替物理删除,查询自动过滤。
三、操作步骤

  1. 继续在上次课(25次课)的基础上更改:
    上次课的工程目录如下图所示:(仔细对照一下,看看自己的工程目录结构是否有错误)

image-20260616073316948
2. 创建自动填充处理器:
右键config文件夹,创建MyMetaObjectHandler类

image-20260616073914190
类中的代码如下所示:

package com.weitoutiao.config;

import com.baomidou.mybatisplus.core.handlers.MetaObjectHandler;
import org.apache.ibatis.reflection.MetaObject;
import org.springframework.stereotype.Component;
import java.time.LocalDateTime;

@Component
public class MyMetaObjectHandler implements MetaObjectHandler {
@Override
public void insertFill(MetaObject metaObject) {
this.strictInsertFill(metaObject, "createTime", LocalDateTime.class, LocalDateTime.now());
this.strictInsertFill(metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now());
}
@Override
public void updateFill(MetaObject metaObject) {
this.strictUpdateFill(metaObject, "updateTime", LocalDateTime.class, LocalDateTime.now());
}
}
3.在News实体中确认已有updateTime字段(已在课次24添加)
4. 测试逻辑删除:
在testSelect文件的最后继续添加测试类NewsMapperTest,添加的位置和代码代码如下:

image-20260616074808352
@SpringBootTest
class NewsMapperTest {
@Autowired
private NewsMapper newsMapper;
@Test
void testDelete() {
int rows = newsMapper.deleteById(1);
System.out.println("删除条数:" + rows);
// 控制台应输出UPDATE news SET deleted=1 WHERE id=1
}
}
有红色错误,就鼠标悬停错误位置,选择导入类。

  1. 运行测试
    逻辑删除前,通过SQLyog查看news表中的数据如下:

image-20260616074808352
运行测试程序,点击图示中的运行按钮

控制台输出如下:

news表中id为1的这条数据,其中的deleted变为了1,代表删除成功。

四、本次课最终的目录结构
image-20260616083029422
五、逻辑删除的概念
逻辑删除不会在数据库中删除数据,只是通过一个字段用来标识被删除的记录,数据仍然保存在数据库中。

在实际的工作当中,因为数据非常重要,为了防止因用户误操作删除数据后无法恢复的问题,我们通常不会对数据做物理删除,即将数据从数据库中直接删除。而是多采用逻辑删除的方式,即不会真正在删除库删除数据,而是使用一个字段来标识它已经被删除。

如使用 isDeleted 字段标识该条记录是否已经被删除,0代表未删除,1代表已删除。此时对数据库做增删改查的SQL语句会发生如下变化:

• 插入:没有变化;

• 删除:转变为修改操作,即修改字段 isDeleted 为1;

• 修改:需要追加 where 子句,以排除 isDeleted 为1 的数据;

• 查询:需要追加 where 子句,以排除 isDeleted 为1 的数据。

例如:

查询数据:select * from user WHERE isDeleted=0

删除数据:UPDATE user SET isDeleted=1 WHERE id=10 AND isDeleted=0

课次26:自动填充 & 逻辑删除
一、教学目标
二、核心知识点(简要)
三、操作步骤
1. 继续在上次课(25次课)的基础上更改:
2. 创建自动填充处理器:
3.在News实体中确认已有updateTime字段(已在课次24添加)
4. 测试逻辑删除:
5. 运行测试
四、本次课最终的目录结构
五、逻辑删除的概念

EOF