在我尝试在我的代码优先的MVC3项目中扩展MVC成员资格提供程序后出现一个奇怪的错误。MVC会员问题 - C#,EntityFramework
的错误是:
EntityType 'MembershipUser' has no key defined. Define the key for this EntityType.
EntitySet "MembershipUsers" is based on type "MembershipUser" that has no keys defined
我已经建立了标准的asp.net成员资格,但增加了一个额外的表&模式叫的UserDetails,其中外键是在aspnet_Users用户ID字段。
将条目插入users表后,我得到UserId并尝试在Useretails表中输入其他详细信息,但这是出现这些错误的时间。这是其他相关的代码。该的AccountController:
if (createStatus == MembershipCreateStatus.Success)
{
//Add other user details
UserRepository _user = new UserRepository();
UserDetails userDetails = new UserDetails();
userDetails.EmployeeNumber = Request.Form["EmployeeNumber"];
userDetails.Title = Request.Form["Title"];
userDetails.FirstName = Request.Form["FirstName"];
userDetails.Initials = Request.Form["Initials"];
userDetails.Surname = Request.Form["Surname"];
userDetails.Nino = Request.Form["Nino"];
_user.AddUserDetails(userDetails, model.Email);
return RedirectToAction("Welcome", "Home");
}
UserRepository:
public MembershipUser GetUserByEmail(string email)
{
MembershipUser user = Membership.GetUser(email);
return user;
}
public void AddUserDetails(UserDetails userDetails, string email)
{
MembershipUser user = GetUserByEmail(email);
Guid userGuid = (Guid)Membership.GetUser(email).ProviderUserKey;
userDetails.UserID = userGuid; //Add UserID foreign key
using (IntranetApplication db = new IntranetApplication())
{
db.UserDetails.Add(userDetails);
db.SaveChanges();
}
}
在db.SaveChanges线误差火灾。
由于MemberShip用户本身并不是实体框架的一部分,是否有人知道我可以如何将UserID设置为主键?我检查了数据库,它已经设置好了,所以不知道我可以在代码中修改它。
谢谢 - 任何帮助赞赏
好吧,这似乎够公平,所以我删除了我的新表和成员表之间的关系,并删除了代码中的链接,但它仍在发生。这可能是我在这里的mvc经验不足,但是如果我只是通过输入一行(包括使用来自成员表的用户标识)来修改UserDetails表,那么还有什么更多的我只能保存到特定的模型,即UserDetails,而不是整个数据库? – 2011-06-08 14:05:54
Doh!我没有删除一个参考 - 我现在已经删除它,它工作正常。感谢您和Craig的信息 - 非常有帮助.. – 2011-06-08 14:18:34