एंटिटी फ्रेमवर्क - नेटिव एसक्यूएल
इकाई ढांचे में आप LINQ का उपयोग करके अपनी इकाई कक्षाओं के साथ क्वेरी कर सकते हैं। आप DbCOntext का उपयोग करके डेटाबेस के खिलाफ सीधे कच्चे SQL का उपयोग करके क्वेरी भी चला सकते हैं। तकनीकों को कोड प्रथम और ईएफ डिजाइनर के साथ बनाए गए मॉडल के समान रूप से लागू किया जा सकता है।
मौजूदा एंटिटी पर SQL क्वेरी
DbSet पर SqlQuery पद्धति एक कच्ची SQL क्वेरी को लिखने के लिए अनुमति देती है जो इकाई उदाहरणों को लौटाएगी। लौटी हुई वस्तुओं को संदर्भ द्वारा ट्रैक किया जाएगा, जैसे वे एक LINQ क्वेरी द्वारा लौटाए गए थे। उदाहरण के लिए -
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();
}
}
}
उपरोक्त कोड डेटाबेस से सभी छात्रों को पुनः प्राप्त करेगा।
गैर-इकाई प्रकारों के लिए SQL क्वेरी
डेटाबेस वर्ग पर SqlQuery पद्धति का उपयोग करके आदिम प्रकारों सहित किसी भी प्रकार की रिटर्निंग एसक्यूएल क्वेरी बनाई जा सकती है। उदाहरण के लिए -
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();
}
}
}
SQL डेटाबेस में शामिल हो जाता है
ExecuteSqlCommnad विधि का उपयोग डेटाबेस में गैर-क्वेरी आदेश भेजने के लिए किया जाता है, जैसे कि इन्सर्ट, अपडेट या डिलीट कमांड। आइए निम्नलिखित कोड पर एक नज़र डालें जिसमें छात्र का पहला नाम आईडी = 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();
}
}
}
उपरोक्त कोड डेटाबेस से सभी छात्रों के पहले नाम को पुनः प्राप्त करेगा।