实体框架员工和任务

本文关键字:任务 框架 实体 | 更新日期: 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; }