我首先学习代码,然后尝试为我的项目创建数据库模型。为了使我的问题变得简单,我将在我的模型中使用两个表 - 用户和角色
我现在的主要问题是我无法通过属性获得角色。例如我的代码:
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; }
你能帮我模型映射吗? 谢谢大家的回答!
答案 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; }