当前位置: 首页 > news >正文

26.自动填充 逻辑删除

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

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

image

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

image

类中的代码如下所示:

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

@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

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

控制台输出如下:
image

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

四、本次课最终的目录结构
{{image.png(uploading...)}}
数据,只是通过一个字段用来标识被删除的记录,数据仍然保存在数据库中。

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

如使用 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

http://www.zskr.cn/news/1541816.html

相关文章:

  • 东北大学资源与土木工程学院升学有多强?学子遍布清北藤校 - 品牌2026
  • 2026年 免扣打包机厂家推荐排行榜:高效耐用/智能节能型打包机源头工厂实力解析与选购指南 - 企业推荐官【官方】
  • ZigBee Power Profile集群API详解:构建智能能源管理系统的核心
  • Microsoft Office LTSC 2021 for Mac 16.110 发布 - 文档、电子表格、演示文稿和电子邮件
  • 跨平台APK资源编辑:开源工具的完整解决方案与技术架构解析
  • 喜马拉雅音频下载终极指南:3步轻松保存付费内容到本地
  • 国产大模型合规落地指南:从RAG优化到政务AI审计要点
  • 2026江苏阳光房安装公司 TOP5实测 - LYL仔仔
  • 国产大模型平替Gemini:免登录合同审查实战指南
  • 2026年6月北京长途搬家公司推荐:五大榜专业评测跨省搬家防损坏价格适用场景 - 品牌推荐
  • 院士团队领衔!探秘东北大学资源与土木工程学院硬核师资与科研平台 - 品牌2026
  • 福州鼓楼托福分数提高培训学校:2026年重磅上新 - 品牌推广大师
  • 推荐一下福州专业的雅思一对一培训正规机构:首发 - 品牌推广大师
  • 2026年气动打包机厂家推荐排行榜:捆扎机、塑钢带打包机、拉紧器品牌与源头公司深度解析 - 品牌发掘
  • 高端腕表保养周期到底怎么算?亨得利维修预约官方联系电话与送修前必知的五条判断标准 - 亨得利官方售后
  • 2026深圳黄金回收横评|走访多家实体门店,称重透明全程不压价,黄金变现避坑指南 - 奢侈品回收测评
  • ArcGIS城市水文脉络解析——以深圳为例
  • 2026太原保险拒赔维权指南:只代理投保人的李晓伟律师团队 - 行路心安
  • 完整版题库手机版 MBTI 测试平台 TOP10 实力排行|中立客观测评汇总 - 时讯资讯
  • Jupyter生产力操作系统:从交互式笔记本到数据工程工作台
  • 情感计算:让 AI Agent Harness Engineering 能够识别并回应用户的情绪
  • RMSprop优化器原理与实战:动态学习率如何解决训练停滞
  • 东北大学资源与土木工程学院:矿业引领的多学科强院 - 品牌2026
  • 机器学习模型服务化:从Notebook到生产环境的七道关卡
  • 免费数据科学资源实战校准指南:从知识幻觉到可验证产出
  • 福州托福培训学校哪家靠谱:2026年上新 - 品牌推广大师
  • 2026瑞安 乐清黄金回收避坑指南:卖金前先看这篇,不要被别人再坑了! - 钦扬网络
  • AI搭系统:不要只让AI写文章,要让AI帮你搭系统 - 招财兔数字员工
  • 逃离塔科夫SPT-AKI存档修改器:5分钟掌握终极游戏进度管理方案
  • 青鲸文化:以战略型包装设计连接品牌与市场 - 资讯报道