架构师_程序员_码农网

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

搜索
查看: 40|回复: 0

[技巧] 数据库软删除(逻辑删除)之字段唯一性的问题

[复制链接]
发表于 前天 16:40 | 显示全部楼层 |阅读模式
需求:很多项目为了防止误删除,避免数据的丢失,删除操作可能并不是物理删除,而是软删除(逻辑删除)。如果表中有唯一性字段,例如:code 这种字段,有了软删除,带来了新的问题。

SQL Server 解决方案

SQL Server 支持过滤索引(Filtered Index),即带有 WHERE 子句的索引,只对满足条件的行创建索引,并且可以在这些部分数据上 enforce 唯一性。

测试脚本如下:
测试如下图:

QQ截图20260107163831.jpg

MySQL 解决方案

MySQL对NULL的处理方式是允许多个NULL值,但不允许相同的非NULL值。只有当所有字段都为非 NULL 值时,才会触发唯一性冲突。

测试脚本如下:
测试如下图:

QQ截图20260107163952.jpg




上一篇:MikroTik(十一)RouterOS 指定网段使用 pptp-client 访问
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2026-1-9 00:03

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表