gpt4 book ai didi

php - 如果可能,当与任何引用都不匹配时,将外键设置为 null

转载 作者:行者123 更新时间:2023-11-29 18:02:13 25 4
gpt4 key购买 nike

我正在下载数据并保存在两个表中,table_1table_2,这些表具有一对多关系:

  • table_1 列:ID、名称
  • 表_2 列:id table_1_id、col1、col2

我无法控制哪个表将首先接收插入。例如,如果我将数据获取到table_2,则table_1中仍然不存在某些条目。然后我收到一个错误

SQLSTATE[23000]:违反完整性约束:1452 无法添加或更新子行:外键约束失败

table_2中,我设置了table_1_id默认值NULL,但仍然失败。

table_1_idtable_1中的任何行都不匹配时,是否可以将其设置为NULL?

我正在使用 Laravel 5.5 和 MySQL

最佳答案

是的,这是可能的。

当 SQL 由于某些错误而无法执行插入时,它会正确抛出适当的异常,就像在 .NET 的 Entity Framework 连接中一样,它会抛出 SQLException 的一些实现。因此,如果由于 FK 约束导致插入失败而想要插入 null,则可以使用约束名称捕获 SQL 抛出的相应异常,然后执行必要的操作。

根据您的情况,使用名称创建约束。并且在代码中当插入失败时, try catch 异常并查看名称。然后尝试通过将其替换为 null 来更改该条目,然后再次尝试插入并查看它是否被插入。

无论您使用什么技术,都会存在 SQL 异常处理。

关于php - 如果可能,当与任何引用都不匹配时,将外键设置为 null,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48247208/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com