इकाई रूपरेखा - संग्रहित प्रक्रियाएँ
एंटिटी फ्रेमवर्क आपको इसकी स्वचालित कमांड पीढ़ी के बजाय या इसके बजाय इकाई डेटा मॉडल में संग्रहीत प्रक्रियाओं का उपयोग करने की अनुमति देता है।
आप डेटाबेस तालिकाओं पर पूर्वनिर्धारित तर्क को करने के लिए संग्रहीत कार्यविधियों का उपयोग कर सकते हैं, और कई संगठनों में ऐसी नीतियां होती हैं जिन्हें इन संग्रहीत प्रक्रियाओं के उपयोग की आवश्यकता होती है।
यह भी निर्दिष्ट कर सकता है कि ईएफ को संस्थाओं को सम्मिलित करने, अपडेट करने या हटाने के लिए अपनी संग्रहीत प्रक्रियाओं का उपयोग करना चाहिए।
यद्यपि गतिशील रूप से निर्मित कमांड सुरक्षित, कुशल हैं, और आम तौर पर उन लोगों की तुलना में बेहतर या बेहतर हैं जो आप खुद लिख सकते हैं, ऐसे कई मामले हैं जहां संग्रहीत प्रक्रियाएं पहले से मौजूद हैं और आपकी कंपनी की कार्यप्रणालियों में तालिकाओं का प्रत्यक्ष उपयोग प्रतिबंधित हो सकता है।
वैकल्पिक रूप से, आप केवल स्टोर पर निष्पादित की गई चीजों पर स्पष्ट नियंत्रण रखना चाहते हैं और संग्रहीत कार्यविधियाँ बनाना पसंद कर सकते हैं।
निम्न उदाहरण फ़ाइल → नई → प्रोजेक्ट से एक नई परियोजना बनाता है।
Step 1 - मध्य फलक से कंसोल एप्लिकेशन का चयन करें और नाम फ़ील्ड में StoredProceduresDemo दर्ज करें।
Step 2 - सर्वर एक्सप्लोरर में अपने डेटाबेस पर राइट-क्लिक करें।
Step 3 - नई क्वेरी का चयन करें और अपने डेटाबेस में एक नई तालिका जोड़ने के लिए T-SQL संपादक में निम्न कोड दर्ज करें।
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 - संपादक पर राइट-क्लिक करें और निष्पादित करें चुनें।
Step 5- अपने डेटाबेस पर राइट-क्लिक करें और रिफ्रेश पर क्लिक करें। आपको अपने डेटाबेस में नई जोड़ी गई तालिका दिखाई देगी।
Step 6 - सर्वर एक्सप्लोरर में, अपने डेटाबेस पर फिर से राइट-क्लिक करें।
Step 7 - नई क्वेरी का चयन करें और अपने डेटाबेस में संग्रहीत प्रक्रिया को जोड़ने के लिए टी-एसक्यूएल संपादक में निम्नलिखित कोड दर्ज करें, जो छात्र ग्रेड वापस कर देगा।
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 - संपादक पर राइट-क्लिक करें और निष्पादित करें चुनें।
Step 9- अपने डेटाबेस पर राइट-क्लिक करें और रिफ्रेश पर क्लिक करें। आप देखेंगे कि आपके डेटाबेस में एक संग्रहीत प्रक्रिया बनाई गई है।
Step 10 - समाधान एक्सप्लोरर में परियोजना के नाम पर राइट-क्लिक करें और जोड़ें → नई आइटम का चयन करें।
Step 11 - इसके बाद Templates फलक में ADO.NET Entity Data Model को चुनें।
Step 12 - नाम के रूप में SPModel दर्ज करें, और फिर जोड़ें पर क्लिक करें।
Step 13 - मॉडल सामग्री चुनें संवाद बॉक्स में, डेटाबेस से EF डिजाइनर का चयन करें और फिर अगला क्लिक करें।
Step 14 - अपने डेटाबेस का चयन करें और अगला पर क्लिक करें।
Step 15 - अपने डेटाबेस ऑब्जेक्ट चुनें संवाद बॉक्स में तालिकाओं, विचारों पर क्लिक करें।
Step 16 - संग्रहीत कार्यविधियों और कार्यों नोड के तहत स्थित GetStudentGradesForCourse फ़ंक्शन का चयन करें और समाप्त पर क्लिक करें।
Step 17 - व्यू → अन्य विंडोज → एंटिटी डेटा मॉडल ब्राउज़र का चयन करें और फ़ंक्शन इंपोर्ट्स के तहत GetStudentGrades पर राइट-क्लिक करें और संपादित करें का चयन करें।
यह निम्नलिखित संवाद का उत्पादन करेगा।
Step 18 - एंटिटीज रेडियो बटन पर क्लिक करें और कम्बोडॉक्स से स्टूडेंटग्रेड को इस संग्रहित प्रक्रिया के रिटर्न प्रकार के रूप में चुनें और ओके पर क्लिक करें।
आइए निम्नलिखित सी # कोड पर एक नज़र डालें जिसमें सभी ग्रेड गेटस्टूडेंटग्रैड्स स्टोरेज प्रक्रिया में छात्र आईडी को पैरामीटर के रूप में प्राप्त करके प्राप्त किए जाएंगे।
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();
}
}
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है तो आपको निम्नलिखित आउटपुट प्राप्त होंगे -
Course ID: 4022, Title: Microeconomics, Grade: 3.00
Course ID: 4041, Title: Macroeconomics, Grade: 3.50
हम अनुशंसा करते हैं कि आप बेहतर समझ के लिए चरण-दर-चरण तरीके से उपरोक्त उदाहरण को निष्पादित करें।