我首先使用实体框架代码,我希望有两个实体:Employee和Task
我希望每个任务都有“CreatedBy”和“AssignedTo”员工。通过这种方式,我可以获得分配给员工的所有任务的列表,以及员工创建的所有任务。同样在任务列表中,我想看看谁创建了它,以及它被分配给谁。
首先使用正确的代码/数据注释方法是什么?
到目前为止,这是我的代码:
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; }
}
答案 0 :(得分:0)
如果您想自己定义外键,它将类似于:
[ForeignKey("CreatedBy")]
public int CreatedByID { get; set; }
public virtual Employee CreatedBy { get; set; }