[英]The entity type 'Microsoft.AspNet.Identity.EntityFramework.IdentityUserLogin<string>' requires a key to be defined
[英]cannot convert from 'string' to 'Microsoft.AspNet.Identity.EntityFramework.IdentityUserRole
我对更新数据库还是比较陌生的,并且我构建了以下代码,用新角色替换了用户角色。 我在这个问题上得到了错误。
public void UpdateRole(string id, string newRoleID)
{
var user = Users.FirstOrDefault(u => u.Id == id);
var oldRoleId = user.Roles.FirstOrDefault().RoleId;
if (user != null && oldRoleId != newRoleID)
{
user.Roles.Remove(oldRoleId);
user.Roles.Add(newRoleID);
}
}
有人可以解释为什么我遇到这个错误吗? 我没有尝试转换任何东西。 我试图删除指定用户ID的RoleId内容,并将其替换为从我的发布操作发送的新ID。
在将string
值(即newRoleID
)传递给它时, user.Roles.Add
方法将使用IdentityUserRole
对象。 您需要在代码中进行以下更改:
user.Roles.Add(new IdentityUserRole { RoleId = newRoleID });
编辑
Remove
方法也需要一个IdentityUserRole
对象。 但请注意,它也必须附加到上下文中。 最简单的方法是通过以下代码:
var user = Users.FirstOrDefault(u => u.Id == id);
var oldRole = user.Roles.FirstOrDefault();
if (user != null && oldRole.RoleId != newRoleID)
{
user.Roles.Remove(oldRole);
user.Roles.Add(new IdentityUserRole { RoleId = newRoleID });
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.