डायनॉम्बीडी - बैच रिट्रीव

बैच एक या एक से अधिक आइटम्स के वापस लौटने के संचालन के गुण। ये ऑपरेशन आम तौर पर वांछित वस्तु (ओं) की पहचान करने के लिए प्राथमिक कुंजी का उपयोग करते हैं। BatchGetItem संचालन व्यक्तिगत संचालन के साथ-साथ अपने स्वयं के अनूठे अवरोधों की सीमा के अधीन हैं।

बैच पुनर्प्राप्ति संचालन में निम्नलिखित अनुरोधों के परिणामस्वरूप अस्वीकृति -

  • 100 से अधिक वस्तुओं के लिए अनुरोध करें।
  • अनुरोध थ्रूपुट से अधिक करें।

बैच पुनः प्राप्त संचालन सीमा से अधिक करने के लिए संभावित ले जाने वाले अनुरोधों का आंशिक प्रसंस्करण करते हैं।

For example- अनुरोध प्रसंस्करण के हिस्से में परिणाम को सीमित करने के लिए आकार में कई वस्तुओं को पर्याप्त रूप से पुनर्प्राप्त करने का अनुरोध, और अनप्रोसेस्ड भाग को नोट करने में त्रुटि संदेश। असंसाधित वस्तुओं की वापसी पर, थ्रॉटलिंग टेबल के बजाय इसे प्रबंधित करने के लिए बैक-ऑफ एल्गोरिथ्म समाधान बनाएं।

BatchGetसंचालन आखिरकार लगातार पठन के साथ प्रदर्शन करते हैं, जिसमें दृढ़ता से संगत लोगों के लिए संशोधन की आवश्यकता होती है। वे समानांतर रूप से पुनर्प्राप्ति भी करते हैं।

Note- लौटी वस्तुओं का क्रम। DynamoDB आइटम सॉर्ट नहीं करता है। यह अनुरोधित वस्तुओं की अनुपस्थिति को भी नहीं दर्शाता है। इसके अलावा, वे अनुरोध क्षमता इकाइयों का उपभोग करते हैं।

सभी बैचगेट संचालन की आवश्यकता है RequestItems रीड कंसिस्टेंसी, एट्रीब्यूट नेम और प्राइमरी कीज जैसे पैरामीटर।

Response - HTTP 200 की प्रतिक्रिया में एक सफल ऑपरेशन का परिणाम होता है, जो कि क्षमता वाली इकाइयों की खपत, टेबल प्रोसेसिंग मेट्रिक्स और किसी भी अनप्रोसेस्ड आइटम जैसी विशेषताओं को इंगित करता है।

जावा के साथ बैच पुनर्प्राप्ति

BatchGet परिचालनों में Java का उपयोग करने के लिए एक DynamoDB वर्ग उदाहरण बनाने की आवश्यकता होती है, TableKeysAndAttributes आइटम के लिए एक प्राथमिक कुंजी मान सूची का वर्णन करने वाला वर्ग उदाहरण, और TableKeysAndAttributes ऑब्जेक्ट को पास करना BatchGetItem तरीका।

निम्नलिखित बैच ऑपरेशन का एक उदाहरण है -

DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient ( 
   new ProfileCredentialsProvider()));  

TableKeysAndAttributes forumTableKeysAndAttributes = new TableKeysAndAttributes 
   (forumTableName);
   
forumTableKeysAndAttributes.addHashOnlyPrimaryKeys (
   "Title",
   "Updates",  
   "Product Line 1"
); 
TableKeysAndAttributes threadTableKeysAndAttributes = new TableKeysAndAttributes (
   threadTableName);
      
threadTableKeysAndAttributes.addHashAndRangePrimaryKeys (
   "ForumTitle",
   "Topic",  
   "Product Line 1",
   "P1 Thread 1", 
   "Product Line 1",
   "P1 Thread 2", 
   "Product Line 2",
   "P2 Thread 1"
); 
BatchGetItemOutcome outcome = dynamoDB.batchGetItem ( 
   forumTableKeysAndAttributes, threadTableKeysAndAttributes);
      
for (String tableName : outcome.getTableItems().keySet()) { 
   System.out.println("Table items " + tableName); 
   List<Item> items = outcome.getTableItems().get(tableName); 
   for (Item item : items) { 
      System.out.println(item); 
   } 
}

आप निम्नलिखित बड़े उदाहरण की समीक्षा कर सकते हैं।

Note- निम्न प्रोग्राम पहले से बनाए गए डेटा स्रोत को मान सकता है। निष्पादित करने का प्रयास करने से पहले, सहायक पुस्तकालयों का अधिग्रहण करें और आवश्यक डेटा स्रोत बनाएं (आवश्यक विशेषताओं के साथ टेबल, या अन्य संदर्भित स्रोत)।

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

package com.amazonaws.codesamples.document;

import java.io.IOException;
import java.util.List;
import java.util.Map;

import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.BatchGetItemOutcome;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.TableKeysAndAttributes;
import com.amazonaws.services.dynamodbv2.model.KeysAndAttributes;

public class BatchGetOpSample { 
   static DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient ( 
      new ProfileCredentialsProvider())); 
      
   static String forumTableName = "Forum"; 
   static String threadTableName = "Thread"; 
     
   public static void main(String[] args) throws IOException { 
      retrieveMultipleItemsBatchGet(); 
   }
   private static void retrieveMultipleItemsBatchGet() {         
      try { 
         TableKeysAndAttributes forumTableKeysAndAttributes = 
            new TableKeysAndAttributes(forumTableName); 
         
         //Create partition key 
         forumTableKeysAndAttributes.addHashOnlyPrimaryKeys (
            "Name", 
            "XYZ Melt-O-tron", 
            "High-Performance Processing"
         ); 
         TableKeysAndAttributes threadTableKeysAndAttributes = 
            new TableKeysAndAttributes(threadTableName); 
         
         //Create partition key and sort key 
         threadTableKeysAndAttributes.addHashAndRangePrimaryKeys (
            "ForumName",
            "Subject",  
            "High-Performance Processing",
            "HP Processing Thread One", 
            "High-Performance Processing",
            "HP Processing Thread Two", 
            "Melt-O-Tron",
            "MeltO Thread One"
         );
         System.out.println("Processing..."); 
         BatchGetItemOutcome outcome = dynamoDB.batchGetItem(forumTableKeysAndAttributes,
            threadTableKeysAndAttributes); 
              
         Map<String, KeysAndAttributes> unprocessed = null;    
         do { 
            for (String tableName : outcome.getTableItems().keySet()) { 
               System.out.println("Table items for " + tableName); 
               List<Item> items = outcome.getTableItems().get(tableName); 
               
               for (Item item : items) { 
                  System.out.println(item.toJSONPretty()); 
               } 
            } 
            // Confirm no unprocessed items 
            unprocessed = outcome.getUnprocessedKeys(); 
                 
            if (unprocessed.isEmpty()) { 
               System.out.println("All items processed."); 
            } else { 
               System.out.println("Gathering unprocessed items..."); 
               outcome = dynamoDB.batchGetItemUnprocessed(unprocessed); 
            } 
         } while (!unprocessed.isEmpty()); 
      } catch (Exception e) { 
         System.err.println("Could not get items."); 
         System.err.println(e.getMessage()); 
      }   
   } 
}