首页 > 代码库 > 经验总结18--EF修改关系,多对多

经验总结18--EF修改关系,多对多

EF修改关系让我费事蛮多时间,能查的资料少,网上试了很多方法都不对。

最后还是自己研究出来了,在这里和大家分享下,有更好的方法也可以分享下。

首先说说我一般做修改功能时,前台传参数,后台使用对象接收,然后使用实体包含,修改策略,提交数据库即可。(之前应该有文章说过)

但是涉及到关系时,重新赋值后,内存可以改变,但没有更新数据库。

试了很多办法,开始以为是配置的问题,一直找相关的内容,都没效果。

下面分享下实现过程:

1、前台传参。

EditID,Name,NewRole

2、后台接收。

User user,注意接收时,避免EditID和实体ID名字相同,避免实体重复。

接收并处理好Role对象。

3、处理数据。

User u=db.Users.Find(EditID);//从数据库查出实体

u.Name=...//给各属性赋值

u.Roles.Clear();//清理角色,这个为啥我也不清楚。没有的话,正常运行会报错,但是调试不报错,很奇怪。这个我也是自己试出来的。

u.Roles=NewRole;//给角色赋值。

4、提交数据库即可。

db.SaveChanges();

简单的说原理,就是修改关系,必须得是从数据库查出的实体,感觉凭技术,EF应该是可以实现的。

有其他方法的朋友可以分享下。