php数据如何实现数据软删除功能_php数据软删除逻辑设计与实现

软删除通过标记字段实现数据逻辑删除,常见方案是在数据库添加deleted_at或is_deleted字段,PHP中可封装模型类统一处理查询、删除、恢复等逻辑,结合withTrashed、onlyTrashed等作用域控制数据可见性,提升数据安全与系统可维护性。

php数据如何实现数据软删除功能_php数据软删除逻辑设计与实现

软删除是一种常见的数据管理方式,它不会真正从数据库中删除记录,而是通过标记字段(如deleted_atis_deleted)来标识该数据是否已被“删除”。这种方式可以保留历史数据、支持数据恢复,并满足合规性要求。在PHP应用中实现软删除功能,通常涉及数据库设计、模型逻辑和业务代码的配合。

1. 数据库字段设计

要在数据库表中支持软删除,需要添加一个用于标识删除状态的字段:

deleted_at:推荐使用时间戳类型(DATETIME 或 TIMESTAMP),未删除时为 NULL,删除时记录当前时间。或使用 is_deleted:布尔类型(TINYINT(1)),0 表示未删除,1 表示已删除。

例如:

CREATE TABLE users (
  id INT AUTO_INCREMENT PRIMARY KEY,
  name VARCHAR(100),
  email VARCHAR(100),
  deleted_at DATETIME DEFAULT NULL,
  INDEX(deleted_at)
);

2. PHP模型层逻辑封装

在PHP中可以通过封装基础模型类来统一处理软删除逻辑。以下是一个简单的示例:

立即学习“PHP免费学习笔记(深入)”;

class Model
{
  protected $table;
  protected $primaryKey = ‘id’;
  protected $softDelete = true;
  protected $deletedAt = ‘deleted_at’;

  // 查询时不包含已软删除的数据
  public function query()
  {
    $sql = “SELECT * FROM {$this->table}”;
    if ($this->softDelete) {
      $sql .= ” WHERE {$this->deletedAt} IS NULL”;
    }
    return $sql;
  }

  // 软删除方法
  public function delete($id)
  {
    if (!$this->softDelete) {
      return “DELETE FROM {$this->table} WHERE {$this->primaryKey} = ?”;
    }
    $now = date(‘Y-m-d H:i:s’);
    $sql = “UPDATE {$this->table} SET {$this->deletedAt} = ? WHERE {$this->primaryKey} = ?”;
    // 执行更新语句(此处省略PDO执行细节)
    return $this->execute($sql, [$now, $id]);
  }

  // 彻底删除(可选)
  public function forceDelete($id)
  {
    $sql = “DELETE FROM {$this->table} WHERE {$this->primaryKey} = ?”;
    return $this->execute($sql, [$id]);
  }

  // 恢复已软删除的数据
  public function restore($id)
  {
    $sql = “UPDATE {$this->table} SET {$this->deletedAt} = NULL WHERE {$this->primaryKey} = ?”;
    return $this->execute($sql, [$id]);
  }
}

子类模型可继承并启用软删除:

class UserModel extends Model
{
  protected $table = ‘users’;
  protected $softDelete = true;
}

3. 查询控制与作用域设计

为了更灵活地控制查询行为,可以在模型中定义不同的查询作用域:

withTrashed():查询包含已软删除的数据。onlyTrashed():只查询已软删除的数据。restore():恢复指定记录。

示例方法:

public function withTrashed()
{
  $this->softDelete = false;
  return $this;
}

public function onlyTrashed()
{
  $sql = “SELECT * FROM {$this->table} WHERE {$this->deletedAt} IS NOT NULL”;
  // 返回符合条件的结果
}

4. 实际调用示例

$userModel = new UserModel();

// 正常查询(不包含已删除)
$users = $userModel->query();

// 删除用户(软删除)
$userModel->delete(1);

// 恢复用户
$userModel->restore(1);

// 查看所有(含已删除)
$allUsers = $userModel->withTrashed()->query();

基本上就这些。通过合理设计字段和封装模型逻辑,PHP中实现软删除并不复杂,但能极大提升系统的数据安全性和可维护性。注意在实际项目中结合框架(如Laravel已内置软删除支持)会更加高效。

以上就是php数据如何实现数据软删除功能_php数据软删除逻辑设计与实现的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1327893.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月12日 14:14:32
下一篇 2025年12月12日 14:14:51

相关推荐

  • php数组赋值方式

    PHP中数组赋值有多种方式:1. 直接定义并赋值,支持索引和关联数组;2. 动态添加或修改元素,按索引或键名赋值;3. 使用range()生成连续值;4. 利用compact()和extract()实现变量与数组转换。 PHP中数组赋值有多种方式,可以根据需求选择合适的方法。最常见的包括直接赋值、逐…

    好文分享 2025年12月13日
    000
  • php源码怎么连接mysql数据库_连php源码mysql数据库指南

    1、使用MySQLi面向过程方式需启用mysqli扩展,通过mysqli_connect()连接并用mysqli_close()关闭;2、面向对象方式创建mysqli实例操作数据库;3、PDO方式需加载pdo_mysql扩展,通过PDO类和DSN连接,提升可移植性。 如果您正在尝试将PHP源码连接到…

    2025年12月13日
    000
  • PHP转发文章源码怎么安装_安装PHP转发文章源码教程【教程】

    首先确保服务器安装Apache/Nginx、PHP 7.4+和MySQL,上传源码至网站根目录;接着配置config.php中的数据库连接信息并赋予用户读写权限;然后设置cache/、logs/等目录权限为755;最后通过浏览器访问index.php,测试链接转发功能并检查错误日志排查问题。 如果您…

    2025年12月13日
    000
  • 网站源码php怎么使用_网站php源码使用搭建与运行步骤【指南】

    1、配置服务器环境需安装XAMPP等集成环境并启动Apache和MySQL服务;2、将PHP源码放入htdocs或www根目录下的项目文件夹;3、通过phpMyAdmin创建数据库并导入SQL文件,修改config.php等配置文件中的数据库连接信息;4、检查并更新.env或settings.php…

    2025年12月13日
    000
  • 怎么改php源码_改php源码逻辑与调试保存法【教程】

    首先理解PHP代码结构,再修改逻辑并调试保存。一、阅读源码明确流程;二、备份后修改条件或函数;三、本地搭建环境测试;四、用日志和断点调试;五、核对无误后提交版本控制并部署。 如果您需要修改PHP源码以调整程序功能或修复逻辑错误,通常需要理解代码结构并进行安全的调试与保存操作。以下是修改PHP源码逻辑…

    2025年12月13日
    000
  • php源码怎么判断后门_php源码判断后门代码与痕迹法【教程】

    识别PHP后门需重点审查eval()、assert()、preg_replace(‘/e’)等函数及base64_decode等编码行为,典型特征如@eval(base64_decode(“…”));攻击者常通过十六进制、变量拼接、动态函数…

    2025年12月13日
    000
  • php桥接模式的作用

    桥接模式通过分离抽象与实现,使两者独立变化,解决类继承导致的紧耦合问题。抽象类(如Shape)持有实现接口(如Renderer)的引用,具体实现由子类(如HtmlRenderer、SvgRenderer)完成。新增形状或渲染方式时,只需扩展新类,无需修改原有代码,符合开闭原则。该模式减少子类数量,避…

    2025年12月13日
    000
  • php面向对象中类的定义

    类是PHP中创建对象的模板,封装属性和方法。使用class定义类,包含public等访问控制的属性和方法,通过$this->访问对象成员;用new实例化对象,__construct()构造函数用于初始化属性,掌握这些即可开展PHP面向对象编程。 在PHP面向对象编程中,类是创建对象的模板,它封…

    2025年12月13日
    000
  • 怎么检查php源码_php源码检查语法与错误检测方法

    使用PHP内置命令行工具可快速检测语法错误,通过php -l命令检查文件并定位问题;现代IDE如PhpStorm和VS Code支持实时语法高亮与错误提示,提升编码效率;借助PHP_CodeSniffer可统一团队代码风格并发现潜在错误;启用error_reporting和日志记录能捕获运行时错误,…

    2025年12月13日
    000
  • php中Suhosin是什么

    Suhosin 是一个针对 PHP 的安全扩展,通过内核补丁和 PHP 扩展提供缓冲区溢出防护、变量过滤、会话加密、禁用危险函数执行及日志审计等功能;它能限制 GET/POST/Cookie 数据大小、阻止变量覆盖攻击、防止 eval() 污染并加密 session;但因 PHP 5.4+ 内置类似…

    2025年12月13日
    000
  • 深入解析PHP浮点数计算与取模操作的精度陷阱

    本文旨在深入探讨PHP中浮点数计算与取模操作时可能遇到的精度问题。通过分析 `(0.29 * 100) % 100` 结果为 `28` 而非 `29` 的现象,揭示了浮点数在计算机内部的表示限制、PHP隐式类型转换机制以及取模运算符的工作原理。文章提供了多种解决方案,包括显式四舍五入和使用BCMat…

    2025年12月13日
    000
  • php7源码怎么样_评php7源码性能特点【解析】

    PHP 7 源码性能提升源于 Zend Engine 3.0 重构,1、采用紧凑 zval 结构和优化 Hashtable 显著降低内存开销并加速数组操作;2、引入抽象语法树(AST)实现解析与编译解耦,提升代码可维护性与优化空间;3、为后续 JIT 编译奠定基础,增强运行时优化潜力;4、使用原生线…

    2025年12月13日
    000
  • 高效使用PHP上传文件到多个SFTP服务器的教程

    本教程详细介绍了如何利用php的`ssh2`扩展实现向多个sftp服务器快速上传文件。文章涵盖了环境准备、sftp连接与认证、文件流操作、错误处理以及上传至多个服务器的策略,旨在提供一个结构清晰、代码实用的专业指南,帮助开发者构建稳定高效的sftp文件传输解决方案。 前言 在现代Web应用开发中,文…

    2025年12月13日
    000
  • PHP 在线表单中实现电子邮件验证与特定域名/TLD拦截教程

    本教程详细介绍了如何在php在线表单中有效验证电子邮件地址,并实现对特定域名或顶级域名(tld)的拦截。文章将演示如何结合使用php内置的`filter_var`函数进行基础格式验证,以及`preg_match`函数通过正则表达式精确匹配并阻止来自黑名单的邮箱地址或特定顶级域名的邮箱,从而提升表单数…

    2025年12月13日
    000
  • WordPress网站安全:深度剖析混淆PHP代码中的RSA公钥与潜在威胁

    本文深入探讨wordpress网站中发现的混淆php代码,通过分析一个包含rsa公钥的复杂代码示例,揭示其可能的远程控制或恶意功能。我们将解释这类代码的特征、工作原理,并指导读者如何识别潜在的恶意行为,强调其对网站安全的严重威胁,以及采取相应防护措施的重要性。 什么是混淆PHP代码及其常见特征? 在…

    2025年12月13日
    000
  • C# RSA加密与PHP解密互操作指南

    本文旨在提供一套完整的跨平台RSA加密解密方案,详细阐述如何在C#应用程序中生成RSA密钥对并进行数据加密,随后在PHP环境中利用私钥对密文进行解密。核心内容包括C#加密实现、XML格式私钥到PEM格式的转换方法,以及PHP解密过程中的Base64解码与OpenSSL函数应用,确保数据在不同语言环境…

    2025年12月13日
    000
  • PHP正则替换:安全地将数组键名转换为带引号的字符串

    本文详细介绍了如何使用php正则表达式(`preg_replace`)批量将代码中未加引号的数组键名(如 `$var[key]`)安全地转换为带引号的字符串字面量(如 `$var[‘key’]`)。核心在于利用高级正则表达式的`(*skip)(*f)`功能,精确匹配并替换目标…

    2025年12月13日
    000
  • 正确处理PHP sprintf中占位符的属性值

    本教程旨在解决PHP `sprintf`函数在使用占位符时,错误地将完整的HTML属性字符串(如`placeholder=”value”`)而非其纯粹的值(`value`)传递给预期接收值的场景。我们将深入分析导致此问题的原因,并提供一个健壮的解决方案,通过直接访问数组中的特…

    2025年12月13日
    000
  • php易盾怎么解密_用易盾解密工具还原php加密内容教程【技巧】

    答案:还原易盾加密PHP代码可采用官方解密接口、静态反混淆、动态调试或内存dump法。首先确认是否拥有授权,通过易盾控制台获取AppKey与AppSecret,调用其解密API获取明文;若无权限,则分析加密文件结构,查找eval(gzinflate(base64_decode(…)))模…

    2025年12月13日
    000
  • php源码怎么留后门_php源码留后门风险与检测方法【警示】

    发现PHP项目异常行为时,应立即检查是否存在后门。首先识别常见后门形式,如eval($_POST[cmd])、assert()、preg_replace(‘/e’)等动态执行代码的函数;其次搜索exec、shell_exec等危险函数调用,确认其参数是否受用户输入控制;接着审…

    2025年12月13日
    000

发表回复

登录后才能评论
关注微信