Kerangka Kerja Entitas - SQL Asli
Dalam Entity Framework Anda dapat melakukan kueri dengan kelas entitas Anda menggunakan LINQ. Anda juga dapat menjalankan kueri menggunakan SQL mentah secara langsung terhadap database menggunakan DbCOntext. Teknik ini dapat diterapkan secara merata ke model yang dibuat dengan Code First dan EF Designer.
Kueri SQL pada Entitas yang Ada
Metode SqlQuery di DbSet memungkinkan kueri SQL mentah untuk ditulis yang akan mengembalikan instance entitas. Objek yang dikembalikan akan dilacak oleh konteksnya sama seperti jika dikembalikan oleh kueri LINQ. Misalnya -
class Program {
static void Main(string[] args) {
using (var context = new UniContextEntities()) {
var students = context.Students.SqlQuery("SELECT * FROM dbo.Student").ToList();
foreach (var student in students) {
string name = student.FirstMidName + " " + student.LastName;
Console.WriteLine("ID: {0}, Name: {1}, \tEnrollment Date {2} ",
student.ID, name, student.EnrollmentDate.ToString());
}
Console.ReadKey();
}
}
}
Kode di atas akan mengambil semua siswa dari database.
Kueri SQL untuk Tipe Non-entitas
Kueri SQL yang mengembalikan instance jenis apa pun, termasuk jenis primitif, dapat dibuat menggunakan metode SqlQuery di kelas Database. Misalnya -
class Program {
static void Main(string[] args) {
using (var context = new UniContextEntities()) {
var studentNames = context.Database.SqlQuery
<string>("SELECT FirstMidName FROM dbo.Student").ToList();
foreach (var student in studentNames) {
Console.WriteLine("Name: {0}", student);
}
Console.ReadKey();
}
}
}
Perintah SQL ke Database
Metode ExecuteSqlCommnad digunakan dalam mengirimkan perintah non-kueri ke database, seperti perintah Sisipkan, Perbarui atau Hapus. Mari kita lihat kode berikut di mana nama depan siswa diperbarui sebagai ID = 1
class Program {
static void Main(string[] args) {
using (var context = new UniContextEntities()) {
//Update command
int noOfRowUpdated = context.Database.ExecuteSqlCommand("Update
student set FirstMidName = 'Ali' where ID = 1");
context.SaveChanges();
var student = context.Students.SqlQuery("SELECT * FROM
dbo.Student where ID = 1").Single();
string name = student.FirstMidName + " " + student.LastName;
Console.WriteLine("ID: {0}, Name: {1}, \tEnrollment Date {2} ",
student.ID, name, student.EnrollmentDate.ToString());
Console.ReadKey();
}
}
}
Kode di atas akan mengambil semua nama depan siswa dari database.