DocumentDB SQL - उपयोगकर्ता-परिभाषित कार्य

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

इन यूडीएफ का उपयोग करके कस्टम एप्लिकेशन लॉजिक का समर्थन करने के लिए DocumentDB SQL सिंटैक्स का विस्तार किया जाता है। UDF को DocumentDB के साथ पंजीकृत किया जा सकता है और फिर SQL क्वेरी के भाग के रूप में संदर्भित किया जा सकता है।

आइए इस उदाहरण के लिए निम्नलिखित तीन दस्तावेजों पर विचार करें।

AndersenFamily दस्तावेज़ इस प्रकार है।

{ 
   "id": "AndersenFamily", 
   "lastName": "Andersen", 
	
   "parents": [ 
      { "firstName": "Thomas", "relationship":  "father" }, 
      { "firstName": "Mary Kay", "relationship":  "mother" } 
   ],
   
   "children": [ 
      { 
         "firstName": "Henriette Thaulow", 
         "gender": "female", 
         "grade": 5, 
         "pets": [ { "givenName": "Fluffy", "type":  "Rabbit" } ] 
      } 
   ],
   
   "location": { "state": "WA", "county": "King", "city": "Seattle" }, 
   "isRegistered": true 
}

SmithFamily दस्तावेज़ इस प्रकार है।

{ 
   "id": "SmithFamily", 
	
   "parents": [ 
      { "familyName": "Smith", "givenName": "James" }, 
      { "familyName": "Curtis", "givenName": "Helen" }
   ], 
	
   "children": [ 
      { 
         "givenName": "Michelle", 
         "gender": "female", 
         "grade": 1 
      }, 
		
      { 
         "givenName": "John", 
         "gender": "male", 
         "grade": 7,
			
         "pets": [ 
            { "givenName": "Tweetie", "type": "Bird" } 
         ] 
      }
   ],
   
   "location": { 
      "state": "NY", 
      "county": "Queens", 
      "city": "Forest Hills" 
   },
   
   "isRegistered": true 
}

WakefieldFamily दस्तावेज़ इस प्रकार है।

{ 
   "id": "WakefieldFamily", 
	
   "parents": [ 
      { "familyName": "Wakefield", "givenName": "Robin" }, 
      { "familyName": "Miller", "givenName": "Ben" } 
   ],
   
   "children": [ 
      { 
         "familyName": "Merriam", 
         "givenName": "Jesse", 
         "gender": "female", 
         "grade": 6,
			
         "pets": [
            { "givenName": "Charlie Brown", "type": "Dog" }, 
            { "givenName": "Tiger", "type": "Cat" }, 
            { "givenName": "Princess", "type": "Cat" } 
         ] 
      },
		
      { 
         "familyName": "Miller", 
         "givenName": "Lisa", 
         "gender": "female", 
         "grade": 3,
			
         "pets": [ 
            { "givenName": "Jake", "type": "Snake" } 
         ] 
      } 
   ],
   
   "location": { "state": "NY", "county": "Manhattan", "city": "NY" }, 
   "isRegistered": false 
}

आइए एक उदाहरण देखें, जहां हम कुछ सरल यूडीएफ बनाएंगे।

निम्नलिखित का कार्यान्वयन है CreateUserDefinedFunctions

private async static Task CreateUserDefinedFunctions(DocumentClient client) { 
   Console.WriteLine(); 
   Console.WriteLine("**** Create User Defined Functions ****"); 
   Console.WriteLine();  
	
   await CreateUserDefinedFunction(client, "udfRegEx");  
}

हमारे पास एक udfRegEx है, और CreateUserDefinedFunction में हमें अपनी स्थानीय फ़ाइल से इसका जावास्क्रिप्ट कोड मिलता है। हम नए UDF के लिए परिभाषा ऑब्जेक्ट का निर्माण करते हैं, और CreateUserDefinedFunctionAsync को संग्रह के SelfLink और udfDefinition ऑब्जेक्ट के साथ निम्न कोड में दिखाया गया है।

private async static Task<UserDefinedFunction>
CreateUserDefinedFunction(DocumentClient client, string udfId) { 
   var udfBody = File.ReadAllText(@"..\..\Server\" + udfId + ".js"); 
	
   var udfDefinition = new UserDefinedFunction { 
      Id = udfId, 
      Body = udfBody 
   }; 
   
   var result = await client
      .CreateUserDefinedFunctionAsync(_collection.SelfLink, udfDefinition); 
   var udf = result.Resource; 
	
   Console.WriteLine("Created user defined function {0}; RID: {1}", 
      udf.Id, udf.ResourceId);  
		
   return udf; 
}

हम परिणाम के संसाधन संपत्ति से नया यूडीएफ प्राप्त करते हैं और इसे वापस कॉल करने वाले को वापस कर देते हैं। मौजूदा यूडीएफ प्रदर्शित करने के लिए, निम्नलिखित का कार्यान्वयन हैViewUserDefinedFunctions। हम फोन करते हैंCreateUserDefinedFunctionQuery और हमेशा की तरह उनके माध्यम से पाश।

private static void ViewUserDefinedFunctions(DocumentClient client) { 
   Console.WriteLine(); 
   Console.WriteLine("**** View UDFs ****"); 
   Console.WriteLine(); 
	
   var udfs = client  
      .CreateUserDefinedFunctionQuery(_collection.UserDefinedFunctionsLink) 
      .ToList();  
		
   foreach (var udf in udfs) { 
      Console.WriteLine("User defined function {0}; RID: {1}", udf.Id, udf.ResourceId); 
   }
}

डॉक्यूमेंटडीबी एसक्यूएल सब्सट्रक्शन या नियमित अभिव्यक्ति के लिए खोज करने के लिए बिल्ट-इन फ़ंक्शन प्रदान नहीं करता है, इसलिए निम्न थोड़ा-एक लाइनर उस अंतराल को भरता है जो एक जावास्क्रिप्ट फ़ंक्शन है।

function udfRegEx(input, regex) { 
   return input.match(regex); 
}

पहले पैरामीटर में इनपुट स्ट्रिंग को देखते हुए, दूसरे पैरामीटर में पैटर्न मिलान स्ट्रिंग में जावास्क्रिप्ट के अंतर्निहित नियमित अभिव्यक्ति समर्थन का उपयोग करें।match। हम उनके नाम में एंडरसन शब्द के साथ सभी दुकानों को खोजने के लिए एक विकल्प क्वेरी चला सकते हैंlastName संपत्ति।

private static void Execute_udfRegEx(DocumentClient client) { 
   var sql = "SELECT c.name FROM c WHERE udf.udfRegEx(c.lastName, 'Andersen') != null";
	
   Console.WriteLine(); 
   Console.WriteLine("Querying for Andersen"); 
	
   var documents = client.CreateDocumentQuery(_collection.SelfLink, sql).ToList();  
   Console.WriteLine("Found {0} Andersen:", documents.Count); 
	
   foreach (var document in documents) { 
      Console.WriteLine("Id: {0}, Name: {1}", document.id, document.lastName); 
   } 
}

ध्यान दें कि हमें उपसर्ग के साथ हर यूडीएफ संदर्भ को अर्हता प्राप्त करनी चाहिए udf। हम बस के साथ एसक्यूएल पारित कर दियाCreateDocumentQueryकिसी भी सामान्य प्रश्न की तरह। अंत में, उपरोक्त प्रश्नों को कॉल करते हैंCreateDocumentClient टास्क

private static async Task CreateDocumentClient() { 
   // Create a new instance of the DocumentClient 
	
   using (var client = new DocumentClient(new Uri(EndpointUrl), AuthorizationKey)){ 
      database = client.CreateDatabaseQuery("SELECT * FROM c WHERE 
         c.id = 'myfirstdb'").AsEnumerable().First();
      collection = client.CreateDocumentCollectionQuery(database.CollectionsLink, 
         "SELECT * FROM c WHERE c.id = 'Families'").AsEnumerable().First();
			 
      await CreateUserDefinedFunctions(client);
   
      ViewUserDefinedFunctions(client);
   
      Execute_udfRegEx(client); 
   } 
}

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

**** Create User Defined Functions ****  
Created user defined function udfRegEx; RID: kV5oANVXnwAlAAAAAAAAYA==  
**** View UDFs ****  
User defined function udfRegEx; RID: kV5oANVXnwAlAAAAAAAAYA==  
Querying for Andersen 
Found 1 Andersen: 
 Id: AndersenFamily, Name: Andersen