gpt4 book ai didi

c# - 删除所有一对多关联项 - Telerik OpenAccess ORM

转载 作者:行者123 更新时间:2023-11-30 15:30:50 25 4
gpt4 key购买 nike

使用 Telerik OpenAccess ORM 我有 2 个对象 UserInvestment。更具体地说,Investments 包含一个指向 User 的外键,作为任何典型的一对多关系。换句话说,每个用户可以有多个投资,但每个投资只能有一个用户。

然后我尝试使用开放访问功能“被管理”

enter image description here

这应该意味着我可以执行类似 User.Investments.Clear(); 的操作,它会删除所有相关投资(或者至少这在多对多关系中工作正常)但是不幸的是,当我尝试这样做时,我遇到了以下错误。

"Update failed: Telerik.OpenAccess.RT.sql.SQLException: Cannot insert the value NULL into column 'UserID', table 'CODECorp.dbo.Investment'; column does not allow nulls. UPDATE fails."

很明显,ORM 试图做的是移除投资对象到用户的关联(即外键),而不是删除它。我已经通过运行 SQL 探查器确认了这一点,并且可以看到它正在运行 Update 而不是 Delete

那么我在这里缺少什么?为什么它错误地尝试删除关联而不是像您期望的那样简单地删除行?

最佳答案

根据设计,在从父对象集合中删除子对象的情况下,IsManaged 设置为 True 的导航属性的行为是删除两个对象之间的关系。换句话说,Telerik Data Access(以前称为 Telerik OpenAccess ORM)会将子记录保留在数据库中,但会生成一条语句,试图将外键设置为 NULL。

这种情况下的解决方案是将集合传递给上下文的 Delete 方法。例如:

dbContext.Delete(User.Investments);
dbContext.SaveChanges();

这将产生必要的 DELETE 语句。有关使用 Telerik 数据访问管理导航属性的更多详细信息,请参阅 this documentation article .

我希望你觉得这是可行的。我期待您的反馈。

关于c# - 删除所有一对多关联项 - Telerik OpenAccess ORM,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21554614/

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