दस्तावेज़डीबी एसक्यूएल - जावास्क्रिप्ट एकीकरण

इन दिनों जावास्क्रिप्ट हर जगह है, और न केवल ब्राउज़रों में। DocumentDB आधुनिक दिन T-SQL के एक प्रकार के रूप में जावास्क्रिप्ट को गले लगाता है और डेटाबेस इंजन के अंदर, मूल रूप से जावास्क्रिप्ट तर्क के ट्रांजेक्शनल निष्पादन का समर्थन करता है। डॉक्‍यूमेंट डी बी ने संग्रहित प्रक्रियाओं और ट्रिगर्स के संदर्भ में जावास्क्रिप्ट-आधारित एप्लिकेशन लॉजिक को सीधे संग्रह पर लागू करने के लिए एक प्रोग्रामिंग मॉडल प्रदान करता है।

आइए एक उदाहरण देखें जहां हम एक सरल स्टोर प्रक्रिया बनाते हैं। निम्नलिखित चरण हैं -

Step 1 - एक नया कंसोल एप्लिकेशन बनाएं।

Step 2- NuGet से .NET SDK में जोड़ें। हम यहां .NET SDK का उपयोग कर रहे हैं, जिसका अर्थ है कि हम अपनी संग्रहीत प्रक्रिया को बनाने, निष्पादित करने और फिर हटाने के लिए कुछ C # कोड लिखेंगे, लेकिन संग्रहीत प्रक्रिया स्वयं जावास्क्रिप्ट में लिखी जाती है।

Step 3 - समाधान एक्सप्लोरर में परियोजना पर राइट-क्लिक करें।

Step 4 - संग्रहीत कार्यविधि के लिए एक नई जावास्क्रिप्ट फ़ाइल जोड़ें और इसे HelloWorldStoreProce.js कहें

हर संग्रहीत प्रक्रिया सिर्फ एक जावास्क्रिप्ट फ़ंक्शन है इसलिए हम एक नया फ़ंक्शन बनाएंगे और स्वाभाविक रूप से हम इस फ़ंक्शन को भी नाम देंगे HelloWorldStoreProce। इससे कोई फर्क नहीं पड़ता कि हम फ़ंक्शन को एक नाम देते हैं। DocumentDB ईद द्वारा इस संग्रहीत प्रक्रिया को संदर्भित करेगा जो हम इसे बनाते समय प्रदान करते हैं।

function HelloWorldStoreProce() { 
   var context = getContext(); 
   var response = context.getResponse(); 
   response.setBody('Hello, and welcome to DocumentDB!'); 
}

सभी संग्रहीत कार्यविधि संदर्भ से प्रतिक्रिया ऑब्जेक्ट प्राप्त करती है और इसे कॉल करती है setBodyकॉलर को स्ट्रिंग वापस करने की विधि। C # कोड में, हम संग्रहीत कार्यविधि बनाएंगे, इसे निष्पादित करेंगे, और फिर इसे हटा देंगे।

संग्रहित प्रक्रियाओं को प्रति संग्रह के लिए बंद कर दिया जाता है, इसलिए हमें संग्रहित प्रक्रिया बनाने के लिए संग्रह के सेल्फलिंक की आवश्यकता होगी।

Step 5 - के लिए पहली क्वेरी myfirstdb डेटाबेस और फिर के लिए MyCollection संग्रह।

किसी संग्रहीत कार्यविधि को बनाना किसी दस्तावेज़ संसाधन में किसी अन्य संसाधन बनाने की तरह है।

private async static Task SimpleStoredProcDemo() {  
   var endpoint = "https://azuredocdbdemo.documents.azure.com:443/"; 
   var masterKey = 
      "BBhjI0gxdVPdDbS4diTjdloJq7Fp4L5RO/StTt6UtEufDM78qM2CtBZWbyVwFPSJIm8AcfDu2O+AfV T+TYUnBQ==";
	  
   using (var client = new DocumentClient(new Uri(endpoint), masterKey)) { 
      // Get database 
      Database database = client 
         .CreateDatabaseQuery("SELECT * FROM c WHERE c.id = 'myfirstdb'") 
         .AsEnumerable() 
         .First();
			
      // Get collection 
      DocumentCollection collection = client 
         .CreateDocumentCollectionQuery(database.CollectionsLink, "SELECT * FROM 
         c WHERE c.id = 'MyCollection'") 
         .AsEnumerable() 
         .First();
			
      // Create stored procedure 
      var sprocBody = File.ReadAllText(@"..\..\HelloWorldStoreProce.js"); 
		
      var sprocDefinition = new StoredProcedure { 
         Id = "HelloWorldStoreProce", 
         Body = sprocBody 
      };
	  
      StoredProcedure sproc = await client.
         CreateStoredProcedureAsync(collection.SelfLink, sprocDefinition); 
      Console.WriteLine("Created stored procedure {0} ({1})", 
         sproc.Id, sproc.ResourceId);
				  
      // Execute stored procedure 
      var result = await client.ExecuteStoredProcedureAsync
      
       (sproc.SelfLink); Console.WriteLine("Executed stored procedure; response = {0}", result.Response); // Delete stored procedure await client.DeleteStoredProcedureAsync(sproc.SelfLink); Console.WriteLine("Deleted stored procedure {0} ({1})", sproc.Id, sproc.ResourceId); } } 
      

Step 6 - पहले नए संसाधन के लिए आईडी के साथ एक डेफिनिशन ऑब्जेक्ट बनाएं और फिर एक बनाएँ तरीकों पर कॉल करें DocumentClientवस्तु। संग्रहीत कार्यविधि के मामले में, परिभाषा में आईडी और वास्तविक जावास्क्रिप्ट कोड शामिल होता है जिसे आप सर्वर पर भेजना चाहते हैं।

Step 7 - बुलाओ File.ReadAllText जेएस फ़ाइल से बाहर संग्रहीत प्रक्रिया कोड निकालने के लिए।

Step 8 - डेफिनिट ऑब्जेक्ट के बॉडी प्रॉपर्टी में स्टोर किए गए प्रक्रिया कोड को असाइन करें।

जहां तक ​​डॉक्यूमेंटडीबी का संबंध है, हम जिस आईडी को यहां निर्दिष्ट करते हैं, परिभाषा में, संग्रहीत कार्यविधि का नाम है, चाहे हम वास्तव में जावास्क्रिप्ट फ़ंक्शन का नाम दें।

फिर भी संग्रहीत प्रक्रियाओं और अन्य सर्वर-साइड ऑब्जेक्ट बनाते समय, यह अनुशंसा की जाती है कि हम जावास्क्रिप्ट फ़ंक्शन का नाम दें और उन फ़ंक्शन नाम उस आईडी से मेल खाते हैं जो हमने DocumentDB के लिए परिभाषा में निर्धारित किया है।

Step 9 - बुलाओ CreateStoredProcedureAsyncमें गुजर रहा है SelfLink के लिए MyCollectionसंग्रह और संग्रहीत कार्यविधि परिभाषा। यह संग्रहीत कार्यविधि बनाता है औरResourceId यह DocumentDB उसे सौंपा गया है।

Step 10 - संग्रहित प्रक्रिया को कॉल करें। ExecuteStoredProcedureAsyncएक प्रकार का पैरामीटर लेता है जिसे आप संग्रहीत प्रक्रिया द्वारा लौटाए गए मान के अपेक्षित डेटा प्रकार पर सेट करते हैं, जिसे आप केवल एक ऑब्जेक्ट के रूप में निर्दिष्ट कर सकते हैं यदि आप एक गतिशील ऑब्जेक्ट वापस चाहते हैं। यह एक ऐसी वस्तु है जिसके गुण रन-टाइम पर बाध्य होंगे।

इस उदाहरण में हम जानते हैं कि हमारी संग्रहीत प्रक्रिया केवल एक स्ट्रिंग लौटा रही है और इसलिए हम कॉल करते हैं ExecuteStoredProcedureAsync<string>

निम्नलिखित Program.cs फ़ाइल का पूर्ण कार्यान्वयन है।

using Microsoft.Azure.Documents; 
using Microsoft.Azure.Documents.Client; 
using Microsoft.Azure.Documents.Linq; 

using System; 
using System.Collections.Generic; 
using System.Diagnostics; 
using System.IO; 

using System.Linq; 
using System.Text; 
using System.Threading.Tasks; 
 
namespace DocumentDBStoreProce { 
   class Program { 
      private static void Main(string[] args) { 
         Task.Run(async () => { 
            await SimpleStoredProcDemo(); 
         }).Wait(); 
      } 
	  
      private async static Task SimpleStoredProcDemo() {  
         var endpoint = "https://azuredocdbdemo.documents.azure.com:443/"; 
         var masterKey = 
            "BBhjI0gxdVPdDbS4diTjdloJq7Fp4L5RO/StTt6UtEufDM78qM2CtBZWbyVwFPSJIm8AcfDu2O+AfV T+TYUnBQ==";  
				
         using (var client = new DocumentClient(new Uri(endpoint), masterKey)) { 
            // Get database 
            Database database = client 
               .CreateDatabaseQuery("SELECT * FROM c WHERE c.id = 'myfirstdb'")
               .AsEnumerable() 
               .First(); 
					
            // Get collection 
            DocumentCollection collection = client 
               .CreateDocumentCollectionQuery(database.CollectionsLink, 
               "SELECT * FROM c WHERE c.id = 'MyCollection'") 
               .AsEnumerable() 
               .First();
					 
            // Create stored procedure 
            var sprocBody = File.ReadAllText(@"..\..\HelloWorldStoreProce.js"); 
				
            var sprocDefinition = new StoredProcedure { 
               Id = "HelloWorldStoreProce", 
               Body = sprocBody 
            };
			
            StoredProcedure sproc = await client
               .CreateStoredProcedureAsync(collection.SelfLink, sprocDefinition);
					
            Console.WriteLine("Created stored procedure {0} ({1})", sproc
               .Id, sproc.ResourceId);
					 
            // Execute stored procedure 
            var result = await client
               .ExecuteStoredProcedureAsync<string>(sproc.SelfLink); 
            Console.WriteLine("Executed stored procedure; response = {0}", 
               result.Response);
					
            // Delete stored procedure 
            await client.DeleteStoredProcedureAsync(sproc.SelfLink); 
            Console.WriteLine("Deleted stored procedure {0} ({1})", 
               sproc.Id, sproc.ResourceId); 
         } 
      } 
   } 
}

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्न आउटपुट का उत्पादन करता है।

Created stored procedure HelloWorldStoreProce (Ic8LAMEUVgACAAAAAAAAgA==)

Executed stored procedure; response = Hello, and welcome to DocumentDB!

जैसा कि उपरोक्त आउटपुट में देखा गया है, प्रतिक्रिया संपत्ति में "हैलो, और डॉक्यूमेंटडीबी में आपका स्वागत है!" हमारी संग्रहीत प्रक्रिया द्वारा लौटाया गया।