实体框架员工和任务
本文关键字:任务 框架 实体 | 更新日期: 2023-09-27 18:30:50
我首先使用实体框架代码,我想有两个实体:员工和任务
我希望每个任务都有"创建者"和"分配给"员工。 通过这种方式,我可以获取分配给员工的所有任务的列表,以及员工创建的所有任务。 同样在任务列表中,我想查看谁创建了它,以及它被分配给了谁。
正确的代码优先/数据注释方法是什么?
这是我到目前为止的代码:
public class DBC : DbContext
{
public DbSet<Employee> Employees { get; set; }
public DbSet<Task> Tasks { get; set; }
}
public class Employee
{
[Key]
public int EmployeeID { get; set; }
[Required]
public int EmployeeName { get; set; }
public virtual ICollection<Task> CreatedTasks { get; set; }
public virtual ICollection<Task> AssignededTasks { get; set; }
}
public class Task
{
[Key]
public int TaskID { get; set; }
public int AssignedToID { get; set; }
public virtual Employee AssignedTo { get; set; }
public int CreatedByID { get; set; }
public virtual Employee CreatedBy { get; set; }
[Required]
public string TaskText { get; set; }
}
如果你想自己定义你的外键,它看起来像这样:
[ForeignKey("CreatedBy")]
public int CreatedByID { get; set; }
public virtual Employee CreatedBy { get; set; }