Kerangka Kerja Entitas - Fungsi Berharga Tabel
Dalam bab ini, mari kita pelajari cara memetakan Fungsi Nilai Tabel (TVF) menggunakan Entity Framework Designer dan cara memanggil TVF dari kueri LINQ.
TVF saat ini hanya didukung di alur kerja Database First.
Ini pertama kali diperkenalkan di Entity Framework versi 5.
Untuk menggunakan TVF, Anda harus menargetkan .NET Framework 4.5 atau lebih tinggi.
Ini sangat mirip dengan prosedur tersimpan tetapi dengan satu perbedaan utama, yaitu, hasil TVF dapat disusun. Ini berarti hasil dari TVF dapat digunakan dalam kueri LINQ sedangkan hasil prosedur tersimpan tidak bisa.
Mari kita lihat contoh berikut untuk membuat proyek baru dari File → New → Project.
Step 1 - Pilih Aplikasi Konsol dari panel tengah dan masukkan TableValuedFunctionDemo di bidang nama.
Step 2 - Di Server explorer, klik kanan pada database Anda.
Step 3 - Pilih New Query dan masukkan kode berikut di editor T-SQL untuk menambahkan tabel baru di database Anda.
IF NOT EXISTS (SELECT * FROM sys.objects WHERE object_id =
OBJECT_ID(N'[dbo].[StudentGrade]') AND type in (N'U'))
BEGIN
CREATE TABLE [dbo].[StudentGrade](
[EnrollmentID] [int] IDENTITY(1,1) NOT NULL,
[CourseID] [int] NOT NULL,
[StudentID] [int] NOT NULL,
[Grade] [decimal](3, 2) NULL,
CONSTRAINT [PK_StudentGrade] PRIMARY KEY CLUSTERED ([EnrollmentID] ASC)
WITH (IGNORE_DUP_KEY = OFF) ON [PRIMARY]
) ON [PRIMARY]
END
GO
Step 4 - Klik kanan pada editor dan pilih Execute.
Step 5- Klik kanan pada database Anda dan klik refresh. Anda akan melihat tabel yang baru ditambahkan di database Anda.
Step 6- Sekarang buat fungsi yang akan mengembalikan nilai siswa untuk kursus. Masukkan kode berikut di editor T-SQL.
CREATE FUNCTION [dbo].[GetStudentGradesForCourse]
(@CourseID INT)
RETURNS TABLE
RETURN
SELECT [EnrollmentID],
[CourseID],
[StudentID],
[Grade]
FROM [dbo].[StudentGrade]
WHERE CourseID = @CourseID
Step 7 - Klik kanan pada editor dan pilih Execute.
Sekarang Anda dapat melihat bahwa fungsinya dibuat.
Step 8 - Klik kanan pada nama proyek di Solution Explorer dan pilih Add → New Item.
Step 9 - Kemudian pilih Model Data Entitas ADO.NET di panel Templat.
Step 10 - Masukkan TVFModel sebagai nama, lalu klik Tambahkan.
Step 11 - Di kotak dialog Pilih Isi Model, pilih desainer EF dari database, lalu klik Berikutnya.
Step 12 - Pilih database Anda dan klik Next.
Step 13 - Di kotak dialog Pilih Objek Database Anda pilih tabel, tampilan.
Step 14 - Pilih fungsi GetStudentGradesForCourse yang terletak di bawah node Stored Procedures and Functions dan klik Finish.
Step 15 - Pilih View → Other Windows → Entity Data Model Browser dan klik kanan GetStudentGradesForCourse di bawah Function Imports dan pilih Edit.
Anda akan melihat dialog berikut.
Step 16 - Klik pada radio button Entities dan pilih Enrollment dari combobox sebagai tipe return dari Function ini dan klik Ok.
Mari kita lihat kode C # berikut di mana semua nilai siswa akan diambil yang terdaftar di Course ID = 4022 di database.
class Program {
static void Main(string[] args) {
using (var context = new UniContextEntities()) {
var CourseID = 4022;
// Return all the best students in the Microeconomics class.
var students = context.GetStudentGradesForCourse(CourseID);
foreach (var result in students) {
Console.WriteLine("Student ID: {0}, Grade: {1}",
result.StudentID, result.Grade);
}
Console.ReadKey();
}
}
}
Ketika kode di atas dikompilasi dan dijalankan, Anda akan menerima output berikut -
Student ID: 1, Grade: 2
Student ID: 4, Grade: 4
Student ID: 9, Grade: 3.5
Kami menyarankan Anda untuk menjalankan contoh di atas dengan cara langkah demi langkah untuk pemahaman yang lebih baik.