EntityFramework员工和任务

时间:2013-09-10 11:04:15

标签: c# entity-framework ef-code-first

我首先使用实体​​框架代码,我希望有两个实体: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; }

    }

1 个答案:

答案 0 :(得分:0)

如果您想自己定义外键,它将类似于:

[ForeignKey("CreatedBy")]
public int CreatedByID { get; set; }
public virtual Employee CreatedBy { get; set; }