Kerangka Kerja Entitas - Prosedur Tersimpan

Kerangka Kerja Entitas memungkinkan Anda untuk menggunakan prosedur yang disimpan dalam Model Data Entitas, bukan, atau dikombinasikan dengan, pembuatan perintah otomatisnya.

  • Anda dapat menggunakan prosedur tersimpan untuk menjalankan logika yang telah ditentukan sebelumnya pada tabel database, dan banyak organisasi memiliki kebijakan yang memerlukan penggunaan prosedur tersimpan ini.

  • Itu juga dapat menentukan bahwa EF harus menggunakan prosedur tersimpan Anda untuk memasukkan, memperbarui, atau menghapus entitas.

  • Meskipun perintah yang dibuat secara dinamis aman, efisien, dan secara umum sama baiknya atau lebih baik daripada yang Anda tulis sendiri, ada banyak kasus di mana prosedur tersimpan sudah ada dan praktik perusahaan Anda mungkin membatasi penggunaan langsung tabel.

  • Alternatifnya, Anda mungkin hanya ingin memiliki kontrol eksplisit atas apa yang dijalankan di penyimpanan dan lebih memilih untuk membuat prosedur tersimpan.

Contoh berikut membuat proyek baru dari File → New → Project.

Step 1 - Pilih Aplikasi Konsol dari panel tengah dan masukkan StoredProceduresDemo 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 - Di Penjelajah server, klik kanan lagi pada database Anda.

Step 7 - Pilih Kueri Baru dan masukkan kode berikut di editor T-SQL untuk menambahkan prosedur tersimpan dalam database Anda, yang akan mengembalikan nilai Siswa.

IF NOT EXISTS (SELECT * FROM sys.objects WHERE object_id = 
   OBJECT_ID(N'[dbo].[GetStudentGrades]') AND type in (N'P', N'PC'))

BEGIN

   EXEC dbo.sp_executesql @statement = N'
   CREATE PROCEDURE [dbo].[GetStudentGrades]
   @StudentID int
   AS
   SELECT EnrollmentID, Grade, CourseID, StudentID FROM dbo.StudentGrade 
   WHERE StudentID = @StudentID
   '
END
GO

Step 8 - Klik kanan pada editor dan pilih Execute.

Step 9- Klik kanan pada database Anda dan klik refresh. Anda akan melihat bahwa prosedur tersimpan dibuat di database Anda.

Step 10 - Klik kanan pada nama proyek di Solution Explorer dan pilih Add → New Item.

Step 11 - Kemudian pilih Model Data Entitas ADO.NET di panel Templat.

Step 12 - Masukkan SPModel sebagai nama, lalu klik Tambahkan.

Step 13 - Di kotak dialog Pilih Isi Model, pilih desainer EF dari database, lalu klik Berikutnya.

Step 14 - Pilih database Anda dan klik Next.

Step 15 - Di kotak dialog Pilih Objek Database Anda, klik tabel, tampilan.

Step 16 - Pilih fungsi GetStudentGradesForCourse yang terletak di bawah node Stored Procedures and Functions dan klik Finish.

Step 17 - Pilih View → Other Windows → Entity Data Model Browser dan klik kanan GetStudentGrades di bawah Function Imports dan pilih Edit.

Ini akan menghasilkan dialog berikut.

Step 18 - Klik pada tombol radio Entities dan pilih StudentGrade dari kotak kombo sebagai tipe pengembalian dari prosedur tersimpan ini dan klik Ok.

Mari kita lihat kode C # berikut di mana semua nilai akan diambil dengan meneruskan ID siswa sebagai parameter dalam prosedur tersimpan GetStudentGrades.

class Program {

   static void Main(string[] args) {

      using (var context = new UniContextEntities()) {

         int studentID = 22;
         var studentGrades = context.GetStudentGrades(studentID);

         foreach (var student in studentGrades) {
            Console.WriteLine("Course ID: {0}, Title: {1}, Grade: {2} ", 
               student.CourseID, student.Course.Title, student.Grade);
         }

         Console.ReadKey();

      }
   }
}

Ketika kode di atas dikompilasi dan dijalankan, Anda akan menerima output berikut -

Course ID: 4022, Title: Microeconomics, Grade: 3.00
Course ID: 4041, Title: Macroeconomics, Grade: 3.50

Kami menyarankan Anda untuk menjalankan contoh di atas dengan cara langkah demi langkah untuk pemahaman yang lebih baik.