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。
总结以上是内存溢出为你收集整理的.net – 使用Entity Framework和System.Data.SQLite进行级联删除的问题全部内容,希望文章能够帮你解决.net – 使用Entity Framework和System.Data.SQLite进行级联删除的问题所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)