[已解决] 完整性约束违规 – 快速提示

WBOY
发布: 2024-08-17 22:50:09
原创
846 人浏览过

如果您正在处理错误:“违反完整性约束:无法添加或更新子行:外键约束失败”,那么您就在正确的文章中。

通常,当您向表中添加新列并将其声明为外键时,您会遇到此错误。

在 SQL 数据库中,外键是一个表中的字段,用于在另一个表中的数据之间建立链接。考虑下面的客户表。

雷雷

现在您想要将您的客户链接到一个组。首先,您应该将新列添加到包含对组表的引用的客户表中:

雷雷

您可以添加外键约束来激活与组表的关系:

雷雷

当您对customers表运行此更改操作时,数据库将验证group_id字段中的ID是否存在于groups表中。

在此检查期间,数据库将引发“完整性违规错误”,因为 group_id 列仍然为空,因此它不包含 groups 表中的任何有效引用。因此 SQL 引擎无法尝试应用外键约束。这是因为空值不是 groups 表的有效外键。

如何解决完整性违规错误

最简单的操作是将新列声明为可为空。

您可以从alter查询中删除“NOT NULL”指令,以允许group_id列包含空值。

这个简单的更改将首先解决问题,因为现在外键也可以为空。您可以运行数据迁移以最终填充customers表中的新group_id列,并计划新版本以重新引入“NOT NULL”约束。

如果在您的应用程序中,如果没有特定的组,客户就不能存在,您应该记住,让 group_id 可以为空,您的数据库不会意识到此约束。

如果您在应用程序中创建实体时犯了错误,数据库不会提醒您。

数据迁移

另一种解决方案是在添加新列的alter查询和添加外键的alter查询之间添加数据迁移作业。

在客户表中获得新的 group_id 列后,您可以运行一个脚本,使用 groups 表中的有效 ID 来填充现有行的此列。

这是执行此任务的查询示例:

雷雷

使用 Laravel 迁移

在现代应用程序中,所有这些任务都是使用迁移工具执行的。它通常在大多数常见的应用程序开发框架中可用。

在下面的示例中,我将向您展示如何使用 Laravel 迁移来处理完整性约束违规问题。

创建迁移:

雷雷

您可以将迁移分为两部分,如下所示:

雷雷

如果您对提高数据库性能感兴趣,可以看看下面关于“智能数据库查询”的文章:
https://inspector.dev/how-to-accelerate-application-performance-with-smart-sql-queries/

督察新人?免费监控您的应用程序

Inspector 是一款专为软件开发人员设计的代码执行监控工具。您不需要在服务器级别安装任何东西,只需安装composer 包就可以开始了。

与其他复杂的一体化平台不同,Inspector 超级简单,并且对 PHP 友好。您可以尝试我们的 Laravel 或 Symfony 包。

如果您正在寻找有效的自动化、深入的见解以及将警报和通知转发到消息传递环境的能力,请免费尝试 Inspector。注册您的帐户。

或在网站上了解更多:https://inspector.dev

[Resolved] Integrity constraint violation – Fast tips

以上是[已解决] 完整性约束违规 – 快速提示的详细内容。更多信息请关注PHP中文网其他相关文章!

来源:dev.to
本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责声明 Sitemap
PHP中文网:公益在线PHP培训,帮助PHP学习者快速成长!