如何在Entity Framework中添加或删除多对多关系?
有一个多对多的UserFeed
表位于User
和Feed
之间,表示类似Twitter的跟随关系。
它只有两个字段,形成一个复合键: UserID
和FeedID
。
我需要编写一个方法,根据布尔标志从订阅源订阅或取消订阅用户。
public void SetSubscriptionFlag (int userId, int storeId, bool subscribe) { }
我是Entity Framework的新手,所以我试图找到并遵循“EF-ish”方式来实现这一目标。
我最初的想法是:
我非常感谢您对我的观点的相关代码段和评论。
谢谢!
你可以使用虚拟对象 – 它肯定适用于插入,我希望它也可以用于删除:
创建新关系:
var user = new User() { Id = userId }; context.Users.Attach(user); var store = new Store() { Id = storeId }; context.Stores.Attach(store); // Now context trackes both entities as "existing" // and you can build a new relation user.Subscriptions.Add(store); context.SaveChanges();
删除现有关系:
上述就是C#学习教程:如何在Entity Framework中添加或删除多对多关系?分享的全部内容,如果对大家有所用处且需要了解更多关于C#学习教程,希望大家多多关注—计算机技术网(www.ctvol.com)!
var user = new User() { Id = userId }; var store = new Store() { Id = storeId }; user.Subscriptions.Add(store); context.Users.Attach(user); // Now context trackes both entities as "existing" // with "existing" relation so you can try to remove it user.Subscriptions.Remove(store); context.SaveChanges();
本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。
ctvol管理联系方式QQ:251552304
本文章地址:https://www.ctvol.com/cdevelopment/1019222.html