我需要一些帮助,在许多情况下向用户添加角色。EF Codefirst更新多对多
所以我有User
很多Role
和Role
有很多User
。
我想我目前Update()
方法在我的存储库不会工作。我如何构建一个存储库方法,允许我删除所有以前的角色并向用户添加新角色?
这是我目前有:
public User UpdateUser(User user, IEnumerable<Expression<Func<User, object>>> properties)
{
if (string.IsNullOrEmpty(user.UserId))
{
throw new InvalidOperationException("user does not exist");
}
else
{
db.Users.Attach(user);
foreach (var selector in properties)
{
string propertyName = Helpers.PropertyToString(selector.Body);
db.Entry(user).Property(propertyName).IsModified = true;
}
}
db.SaveChanges();
return user;
}
这是更新用户的正确方法?我假设一切都是分离的。这是我如何调用该给角色添加到用户:
User user = new User();
user.UserId = userId;
user.Roles = new Domain.Role{ RoleId = 1}; //Assuming there is a role with ID = 1
userRepo.UpdateUser(user, new List<Expression<Func<User, object>>>
{
u => u.Roles
});