加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

.net – 使用Entity Framework和System.Data.SQLite进行级联删除

发布时间:2020-12-12 19:13:50 所属栏目:百科 来源:网络整理
导读:我有一个SQLite数据库设置,所以当我删除一个人的删除是级联的。当我手动删除一个人(引用PersonID的所有记录被删除)时,这样工作正常。但是当我使用Entity Framework删除Person时,我会收到一个错误: System.InvalidOperationException:操作失败:无法更改
我有一个SQLite数据库设置,所以当我删除一个人的删除是级联的。当我手动删除一个人(引用PersonID的所有记录被删除)时,这样工作正常。但是当我使用Entity Framework删除Person时,我会收到一个错误:

System.InvalidOperationException:操作失败:无法更改关系,因为一个或多个外键属性不可为空。当对关系进行更改时,将相关的外键属性设置为空值。如果外键不支持空值,则必须定义新关系,必须为外键属性分配另一个非空值,否则必须删除不相关的对象。

我不明白为什么会发生这种情况。我的触发器设置为清除所有相关对象,然后再删除被要求删除的对象。

当我进入模型编辑器并检查关系的属性时,它不会显示OnDelete属性的操作。为什么通过从数据库中拉出来可以正确设置?如果我将这个值改为Cascade,那么所有的工作都可以正常工作,但是我宁愿不要依赖这个手动更改,因为如果我从数据库中刷新我的模型,它会丢失。

这是我的表的相当的SQL。

CREATE TABLE [SomeTable] 
(
    [SomeTableID] INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,[PersonID] INTEGER NOT NULL REFERENCES [Person](PersonID) ON DELETE CASCADE
)
CREATE TABLE [Person]
(
    [PersonID] INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT
)
我刚刚处理了这个确切的问题。原来,当我使用EF从数据库…选项更新模型时,它没有正确地获得删除的“级联”规则。

尝试转到您的EF数据库模型,单击导致问题的关联,然后确保End1 OnDelete(可以是End2,取决于数据库方案)设置为Cascade。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读