2017-02-16 35 views
0

我想在MVC中使用代碼第一種方法做一個示例應用程序,所以我沒有任何數據庫。現在我已經設置了所有的類文件和上下文類。在下一步中,我創建了一個控制器(Emplty)並且想要創建自己的創建/列表/刪除功能。我該怎麼做。如何在實體框架Codefirst方法中創建自己的/自定義控制器

有些代碼低於

 public class Employee 
      { 
       public int EmployeeID { get; set; } 
       public string Name { get; set; } 
       public int Age { get; set; } 

       public int DepartmentID { get; set; }//Foreign Key 

       public virtual ICollection<Enrollment> Enrollments { get; set; } 
      } 

     public class Department 
     { 
      public int DepartmentID { get; set; } 
      public string DepartmentName { get; set; } 

      public virtual ICollection<Enrollment> Enrollments { get; set; } 
     } 

    public class EmployeeDBContext: DbContext 
     { 
      public EmployeeDBContext() 
       : base("EmployeeDBContext")//EmployeeDBContext will be name of database. 
      { } 

      public virtual DbSet<Employee> Employees { get; set; } 
      public virtual DbSet<Department> Departments { get; set; } 
      public virtual DbSet<Enrollment> Enrollments { get; set; } 
     } 


public class EmployeeInitializer:DropCreateDatabaseIfModelChanges<EmployeeDBContext> 
    { 
     protected override void Seed(EmployeeDBContext context) 
     { 
      var employee = new List<Employee> 
      { 
       new Employee{EmployeeID=1, Name="Aman", Age=15, DepartmentID=11}, 
       new Employee {EmployeeID=2, Name="Supriya", Age=12, DepartmentID=22}, 
       new Employee {EmployeeID=3, Name="Rishabh", Age=10, DepartmentID=44} 
      }; 

      employee.ForEach(x => context.Employees.Add(x)); 
      context.SaveChanges(); 

      var department = new List<Department> { 
      new Department{DepartmentID=11, DepartmentName="IT"}, 
      new Department{DepartmentID=22, DepartmentName="HR"}, 
      new Department{DepartmentID=33, DepartmentName="Mechanical"}, 
      new Department{DepartmentID=44, DepartmentName="NGO"} 
      }; 

      department.ForEach(x=>context.Departments.Add(x)); 
      context.SaveChanges(); 

      var enrollment = new List<Enrollment>() { 
      new Enrollment{EnrollmentID=111, EmployeeID=1, DepartmentID=11}, 
      new Enrollment{EnrollmentID=222, EmployeeID=3, DepartmentID=44}, 
      new Enrollment{EnrollmentID=333, EmployeeID=2, DepartmentID=22} 
      }; 
      enrollment.ForEach(x=>context.Enrollments.Add(x)); 
      context.SaveChanges(); 

     } 
    } 

我想從以下控制器添加代碼以後

public ActionResult CreateEmployee(Employee employee) 
{ 

    //my desired code here 
    return View(); 
} 


[HttpGet] 
public ActionResult ListEmployee() 
{ 
//my desired code here 
    return View(); 
} 
+0

搜索「使用EF的示例MVC應用程序會讓您的答案更快,然後在此等待準備就緒的解決方案。 –

回答

0

你的意思怎麼做:

[HttpGet] 
    public ActionResult ListEmployee() 
    { 
    //my desired code here 
    using(var context=new EmployeeDBContext()) 
    { 
    return View(context. Employee.ToList()); 
    } 

    } 

[HttpPost] 
[Route("api/Employee/CreateEmployee")] 
public ActionResult CreateEmployee([FromBody]Employee employee) 
{ 
//add to ef 
_db.Add(employee); 
_db.SaveChanges(); 

    //my desired code here 
    return Ok(); 
} 
+0

是的。就像獲得員工列表如何插入以創建員工一樣? –

+0

希望它可以幫助..如果是的話...它的PLZ :-) –

相關問題