-2

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

    }
4

1 回答 1

0

如果您想自己定义外键,它看起来像:

[ForeignKey("CreatedBy")]
public int CreatedByID { get; set; }
public virtual Employee CreatedBy { get; set; }
于 2013-09-10T14:49:52.067 回答