กรอบเอนทิตี - มุมมอง

มุมมองเป็นวัตถุที่มีข้อมูลที่ได้รับจากแบบสอบถามที่กำหนดไว้ล่วงหน้า มุมมองคือวัตถุเสมือนหรือตารางที่ชุดผลลัพธ์ได้มาจากแบบสอบถาม คล้ายกับตารางจริงมากเพราะประกอบด้วยคอลัมน์และแถวของข้อมูล ต่อไปนี้เป็นการใช้มุมมองทั่วไป -

  • กรองข้อมูลของตารางพื้นฐาน
  • กรองข้อมูลเพื่อความปลอดภัย
  • รวมศูนย์ข้อมูลที่กระจายไปทั่วเซิร์ฟเวอร์หลายเครื่อง
  • สร้างชุดข้อมูลที่ใช้ซ้ำได้

มุมมองสามารถใช้ในลักษณะเดียวกันกับที่คุณสามารถใช้ตาราง ในการใช้มุมมองเป็นเอนทิตีอันดับแรกคุณจะต้องเพิ่มมุมมองฐานข้อมูลไปยัง EDM หลังจากเพิ่มมุมมองให้กับโมเดลของคุณแล้วคุณสามารถทำงานกับมันได้เช่นเดียวกับเอนทิตีปกติยกเว้นการดำเนินการสร้างอัปเดตและลบ

ลองมาดูวิธีเพิ่มมุมมองลงในโมเดลจากฐานข้อมูล

Step 1 - สร้างโครงการแอปพลิเคชันคอนโซลใหม่

Step 2 - คลิกขวาที่โปรเจ็กต์ในตัวสำรวจโซลูชันแล้วเลือกเพิ่ม→รายการใหม่

Step 3 - เลือก ADO.NET Entity Data Model จากบานหน้าต่างตรงกลางและป้อนชื่อ ViewModel ในฟิลด์ Name

Step 4 - คลิกปุ่มเพิ่มซึ่งจะเปิดกล่องโต้ตอบตัวช่วยสร้างโมเดลข้อมูลเอนทิตี

Step 5 - เลือก EF Designer จากฐานข้อมูลและคลิกปุ่มถัดไป

Step 6 - เลือกฐานข้อมูลที่มีอยู่แล้วคลิกถัดไป

Step 7 - เลือก Entity Framework 6.x แล้วคลิกถัดไป

Step 8 - เลือกตารางและมุมมองจากฐานข้อมูลของคุณแล้วคลิกเสร็จสิ้น

คุณสามารถเห็นในหน้าต่างตัวออกแบบว่ามุมมองถูกสร้างขึ้นและคุณสามารถใช้ในโปรแกรมเป็นเอนทิตีได้

ในตัวสำรวจโซลูชันคุณจะเห็นว่าคลาส MyView ถูกสร้างขึ้นจากฐานข้อมูลด้วย

มาดูตัวอย่างที่ดึงข้อมูลทั้งหมดจากมุมมอง ต่อไปนี้เป็นรหัส -

class Program {

   static void Main(string[] args) {

      using (var db = new UniContextEntities()) {

         var query = from b in db.MyViews
            orderby b.FirstMidName select b;

         Console.WriteLine("All student in the database:");

         foreach (var item in query) {
            Console.WriteLine(item.FirstMidName + " " + item.LastName);
         }

         Console.WriteLine("Press any key to exit...");
         Console.ReadKey();
      }
   }
}

เมื่อดำเนินการโค้ดด้านบนคุณจะได้รับผลลัพธ์ต่อไปนี้ -

All student in the database:
Ali Khan
Arturo   finand
Bill Gates
Carson Alexander
Gytis Barzdukas
Laura Norman
Meredith Alonso
Nino Olivetto
Peggy Justice
Yan Li
Press any key to exit...

เราขอแนะนำให้คุณดำเนินการตามตัวอย่างข้างต้นในลักษณะทีละขั้นตอนเพื่อความเข้าใจที่ดีขึ้น