Register Register Member Login Member Login Member Login Forgot Password ??
PHP , ASP , ASP.NET, VB.NET, C#, Java , jQuery , Android , iOS , Windows Phone
 

Registered : 109,027

HOME > .NET Framework > Forum > ASP.NET MVC4 Entity Framework การเอาข้อมูลจากหลาย Table มาแสดง



 

ASP.NET MVC4 Entity Framework การเอาข้อมูลจากหลาย Table มาแสดง

 



Topic : 109797



โพสกระทู้ ( 1 )
บทความ ( 0 )



สถานะออฟไลน์




สวัสดีครับ รบกวนขอคำชี้แนะครับ
ทดลองเขียน ASP.NET MVC4 โดยใช้ Entity Framework ครับ
จะลองทำ โปรแกรม พนักงาน ยืม-คืน อุปกรณ์ ครับ
ผมใช้วิธีเปิดหนังสือ ฝรั้ง เขียนตามตัวอย่างไปนะครับ
ยังไม่ค่อยเข้าใจเท่าไร โดยเฉพาะการ Join เอาข้อมูลมาแสดงครับ

Code (C#)
[Entity folder ]  
 public class Equipment
 {
        public int EquipmentID { get; set; }
        public string EquipmentCode { get; set; }
        public string EquipmentName { get; set; }
        public string EquipmentDescription { get; set; }
}

public class Employee
{
        public int EmployeeID { get; set; }
        public string  EmployeeCode { get; set; }
        public string  EmployeeName { get; set; }
}	

public class EquipmentTran
{
       public int { get; set; }
       public LendDate datetime {get; set; }	
        public int EmployeeID { get; set; }
        public int EquipmentID { get; set; }
        public string  Side { get; set; } 
	// IN,OUT
}

[Abstract folder ]
public interface IEquipmentRepository
    {
        IQueryable<Equipment> Equipments { get; }
    }

public interface IEmployeeRepository
    {
        IQueryable<Employee> Employees { get; }
    }
public interface IEquipmentTran
    {
        IQueryable<EquipmentTran> EquipmentTrans { get; }
    }

[Concrete folder ]
public class EFEquipmentRepository : IEquipmentRepository
{
        private EFDbContext context = new EFDbContext();
        public IQueryable<Equipment> Equipments 
        {
            get { return context.Equipments; }
        }
}

public class EFEmployeeRepository : IEmployeeRepository
{
        private EFDbContext context = new EFDbContext();
        public IQueryable<Employee> Employees 
        {
            get { return context.Employees; }
        }
}
public class EFEquipmentTranRepository : IEquipmentTranRepository
{
        private EFDbContext context = new EFDbContext();
        public IQueryable<EquipmentTran> EquipmentTrans 
        {
            get { return context.EquipmentTrans; }
        }
}

    public class EFDbContext : DbContext
    {
        public DbSet<Equipment> Equipments { get; set; }
        public DbSet<Employee> Employees { get; set; }
        public DbSet<EquipmentTran> EquipmentTrans { get; set; }
    }


[Controller folder]
... ใช้ Ninject ตามหนังสือ..
ninjectKernel.Bind<IEquipmentTranRepository>().To<EFEquipmentTranRepository>();
ninjectKernel.Bind<IEquipmentRepository>().To<EFEquipmentRepository>();
ninjectKernel.Bind<IEmployeeRepository>().To<EFEmployeeRepository>();

Controller คุมการแสดง List ด้วย ViewModel โครงสร้างเดียวกับ Model ของ Entity ครับ

Code (C#)
    public class EmployeeController : Controller
    {
      private IEmployeeRepository repository;
        public ViewResult List()
        {
                EmployeeListViewModel model = new EmployeeListViewModel
                {
                    Employees = repository.Employees;
                };
                return View(model);
            };
}

    public class EquipmentController : Controller
    {
      private IEquipmentRepository repository;
        public ViewResult List()
        {
                EquipmentListViewModel model = new EquipmentListViewModel
                {
                    Equipments = repository.Equipment;
                };
                return View(model);
            };
}

   public class EquipmentTranController : Controller
    {
      private IEquipmentTranRepository repository;
        public ViewResult List()
        {
                EquipmentTranListViewModel model = new EquipmentTranListViewModel
                {
                    Employees = repository.Employees;
                };
                return View(model);
            };
}
//////////////

View ใช้ Razor ครับ Map คอลัมน์ แสดงตรงๆ ครับ
///////////////
ตอนนี้ อยากให้ ใน View List ของ EquipmentTran เพิ่ม 2 คอลัมน์แสดง ชื่อ อุปกรณ์ กับชื่อ พนักงาน แทนที่จะเป็น EquipmentID, EmployeeID ครับ
ผมจะต้องไปทำ อะไรตรงไหน ถึงจะ ได้ผลตามที่อยากได้ครับ
ไม่มีตัวอย่างผมไปไม่เป็นเลยครับ

ขอคำชี้แนะครับ ขอบคุณมากครับ



Tag : Web (ASP.NET), VS 2012 (.NET 4.x)







Move To Hilight (Stock) 
Send To Friend.Bookmark.
Date : 2014-07-08 15:54:18 By : thanestalk View : 1633 Reply : 1
 

 

No. 1



โพสกระทู้ ( 74,058 )
บทความ ( 838 )

สมาชิกที่ใส่เสื้อไทยครีเอท

สถานะออฟไลน์
Twitter Facebook

ถ้าใช้ LinQ ใช้การ JOIN ก็ได้ครับ หรือไม่ก็ทำเป็น View บน Database ก่อนครับ






แสดงความคิดเห็นโดยอ้างถึง ความคิดเห็นนี้
Date : 2014-07-09 10:51:15 By : mr.win
 

   

ค้นหาข้อมูล


   
 

แสดงความคิดเห็น
Re : ASP.NET MVC4 Entity Framework การเอาข้อมูลจากหลาย Table มาแสดง
 
 
รายละเอียด
 
ตัวหนา ตัวเอียง ตัวขีดเส้นใต้ ตัวมีขีดกลาง| ตัวเรืองแสง ตัวมีเงา ตัวอักษรวิ่ง| จัดย่อหน้าอิสระ จัดย่อหน้าชิดซ้าย จัดย่อหน้ากึ่งกลาง จัดย่อหน้าชิดขวา| เส้นขวาง| ขนาดตัวอักษร แบบตัวอักษร
ใส่แฟลช ใส่รูป ใส่ไฮเปอร์ลิ้งค์ ใส่อีเมล์ ใส่ลิ้งค์ FTP| ใส่แถวของตาราง ใส่คอลัมน์ตาราง| ตัวยก ตัวห้อย ตัวพิมพ์ดีด| ใส่โค้ด ใส่การอ้างถึงคำพูด| ใส่ลีสต์
smiley for :lol: smiley for :ken: smiley for :D smiley for :) smiley for ;) smiley for :eek: smiley for :geek: smiley for :roll: smiley for :erm: smiley for :cool: smiley for :blank: smiley for :idea: smiley for :ehh: smiley for :aargh: smiley for :evil:
Insert PHP Code
Insert ASP Code
Insert VB.NET Code Insert C#.NET Code Insert JavaScript Code Insert C#.NET Code
Insert Java Code
Insert Android Code
Insert Objective-C Code
Insert XML Code
Insert SQL Code
Insert Code
เพื่อความเรียบร้อยของข้อความ ควรจัดรูปแบบให้พอดีกับขนาดของหน้าจอ เพื่อง่ายต่อการอ่านและสบายตา และตรวจสอบภาษาไทยให้ถูกต้อง

อัพโหลดแทรกรูปภาพ

Notice

เพื่อความปลอดภัยของเว็บบอร์ด ไม่อนุญาติให้แทรก แท็ก [img]....[/img] โดยการอัพโหลดไฟล์รูปจากที่อื่น เช่นเว็บไซต์ ฟรีอัพโหลดต่าง ๆ
อัพโหลดแทรกรูปภาพ ให้ใช้บริการอัพโหลดไฟล์ของไทยครีเอท และตัดรูปภาพให้พอดีกับสกรีน เพื่อความโหลดเร็วและไฟล์ไม่ถูกลบทิ้ง

   
  เพื่อความปลอดภัยและการตรวจสอบ กระทู้ที่แทรกไฟล์อัพโหลดไฟล์จากที่อื่น อาจจะถูกลบทิ้ง
 
โดย
อีเมล์
บวกค่าให้ถูก
<= ตัวเลขฮินดูอารบิก เช่น 123 (หรือล็อกอินเข้าระบบสมาชิกเพื่อไม่ต้องกรอก)







Exchange: นำเข้าสินค้าจากจีน, Taobao, เฟอร์นิเจอร์, ของพรีเมี่ยม, ร่ม, ปากกา, power bank, แฟลชไดร์ฟ, กระบอกน้ำ

Load balance : Server 01
ThaiCreate.Com Logo
© www.ThaiCreate.Com. 2003-2024 All Rights Reserved.
ไทยครีเอทบริการ จัดทำดูแลแก้ไข Web Application ทุกรูปแบบ (PHP, .Net Application, VB.Net, C#)
[Conditions Privacy Statement] ติดต่อโฆษณา 081-987-6107 อัตราราคา คลิกที่นี่