2011-06-08 54 views
3

在我尝试在我的代码优先的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设置为主键?我检查了数据库,它已经设置好了,所以不知道我可以在代码中修改它。

谢谢 - 任何帮助赞赏

回答

3

为了扩大克雷格所说的话,我知道链接会员表格很方便,但没有必要。编写你的查询来接受用户ID字段作为参数,然后从Membership.GetUser()。ProviderUserKey传递它。

另外,不要试图在UserName上键入你的表,因为如果一个用户创建了一个具有特定名字的用户,然后被删除,那么会产生一个安全问题,然后创建一个同名的新用户。

+0

好吧,这似乎够公平,所以我删除了我的新表和成员表之间的关系,并删除了代码中的链接,但它仍在发生。这可能是我在这里的mvc经验不足,但是如果我只是通过输入一行(包括使用来自成员表的用户标识)来修改UserDetails表,那么还有什么更多的我只能保存到特定的模型,即UserDetails,而不是整个数据库? – 2011-06-08 14:05:54

+0

Doh!我没有删除一个参考 - 我现在已经删除它,它工作正常。感谢您和Craig的信息 - 非常有帮助.. – 2011-06-08 14:18:34

4

你有两个问题。

  1. 您对MembershipUser的映射没有定义关键字,无论是隐式还是显式。你不显示映射代码,但这就是错误所说的。
  2. 反正你不应该试图映射MembershipUser

(2)这里最重要的一点,因为它使(1)种不相关。 You should never depend on the SQL Provider DB tables。你也不应该使用MembershipUser作为一个实体,因为你不控制它,并且那些保持它的人不打算以这种方式使用它。

从Membership API获取您的会员资料数据,而不是通过EF直接点击数据库。