代码优先于对象映射,无法获取表属性

时间:2015-12-22 20:45:34

标签: c# .net asp.net-mvc entity-framework-5 code-first

我首先学习代码,然后尝试为我的项目创建数据库模型。为了使我的问题变得简单,我将在我的模型中使用两个表 - 用户和角色

Database diagram in SQL Server

我现在的主要问题是我无法通过属性获得角色。例如我的代码:

var role = dbContext.Users.FirstOrDefault(n => n.UserId== id).Role;

返回null。我认为这是模型映射的问题。我的用户类看起来像:

 public class User
    {
        public User()
        {
            Role = new Role();
        }
        public int UserId { get; set; }
        [Required]
        public string Login { get; set; }
        [Required]
        public string Name { get; set; }
        [Required]
        public string Password { get; set; }
        public DateTime CreationDate { get; set; }

        public DateTime LastLoginDate { get; set; }

        [ForeignKey("Role")]
        public int RoleId { get; set; }

        public Role Role { get; set; }

        public virtual ICollection<Telephone> Telephones { get; set; }
    }

我的角色课程:

 public class Role
    {
        public Role()
        {
            Users = new List<User>();
        }
        public int RoleId { get; set; }
        public string RoleName { get; set; }
        public string RoleDescription { get; set; }

        public ICollection<User> Users { get; set; }
    }

这两个类的db上下文:

public CallCenterContext() : base(@"CONNECTIONSTRING")
    {

    }

    public DbSet<User> Users { get; set; }
    public DbSet<Role> Roles { get; set; }

你能帮我模型映射吗? 谢谢大家的回答!

1 个答案:

答案 0 :(得分:1)

您应该在查询中包含该角色,如下所示:

var role = dbContext.Users
         .Include("Role") // <----- add this
         .FirstOrDefault(n => n.UserId== id).Role;

您也可以使用.Include(u => u.Role)代替.Include("Role"),这是更好但不适用于MySql数据库和某些特定控制器。

此外,您应该在User类中将Role属性声明为virtual:

  public virtual Role Role { get; set; }