DynamoDB - आइटम प्राप्त करना

DynamoDB में किसी आइटम को प्राप्त करने के लिए GetItem का उपयोग करना पड़ता है, और तालिका का नाम और आइटम प्राथमिक कुंजी निर्दिष्ट करना होता है। एक हिस्से को छोड़ने के बजाय एक पूर्ण प्राथमिक कुंजी शामिल करना सुनिश्चित करें।

उदाहरण के लिए, मिश्रित कुंजी की सॉर्ट कुंजी को छोड़ना।

GetItem व्यवहार तीन चूक के अनुरूप है -

  • यह अंततः सुसंगत रीड के रूप में निष्पादित होता है।
  • यह सभी गुण प्रदान करता है।
  • यह इसकी क्षमता इकाई की खपत का विवरण नहीं देता है।

ये पैरामीटर आपको डिफ़ॉल्ट GetItem व्यवहार को ओवरराइड करने की अनुमति देते हैं।

एक आइटम पुनर्प्राप्त करें

DynamoDB कई सर्वरों पर वस्तुओं की कई प्रतियों को बनाए रखने के माध्यम से विश्वसनीयता सुनिश्चित करता है। प्रत्येक सफल लेखन इन प्रतियों को बनाता है, लेकिन निष्पादित करने के लिए पर्याप्त समय लेता है; अंत में सुसंगत अर्थ। इसका मतलब है कि आप किसी आइटम को लिखने के तुरंत बाद पढ़ने का प्रयास नहीं कर सकते।

आप GetItem के डिफ़ॉल्ट अंततः सुसंगत रीड को बदल सकते हैं, हालांकि, अधिक वर्तमान डेटा की लागत अधिक क्षमता इकाइयों की खपत बनी हुई है; विशेष रूप से, दो बार जितना। नोट डायनॉम्बीडी आमतौर पर एक सेकंड के भीतर हर कॉपी में स्थिरता प्राप्त करता है।

इस कार्य को करने के लिए आप GUI कंसोल, जावा या किसी अन्य टूल का उपयोग कर सकते हैं।

जावा का उपयोग करके आइटम पुनर्प्राप्ति

आइटम पुनर्प्राप्ति कार्यों में जावा का उपयोग करने के लिए डायनमोबडी क्लास इंस्टेंस, टेबल क्लास इंस्टेंस बनाने और टेबल इंस्टेंस के गेट इट विधि को कॉल करने की आवश्यकता होती है। फिर आइटम की प्राथमिक कुंजी निर्दिष्ट करें।

आप निम्न उदाहरण की समीक्षा कर सकते हैं -

DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient( 
   new ProfileCredentialsProvider()));  
Table table = dynamoDB.getTable("ProductList");  
Item item = table.getItem("IDnum", 109);

कुछ मामलों में, आपको इस ऑपरेशन के लिए मापदंडों को निर्दिष्ट करने की आवश्यकता है।

निम्नलिखित उदाहरण का उपयोग करता है .withProjectionExpression तथा GetItemSpec पुनर्प्राप्ति विनिर्देशों के लिए -

GetItemSpec spec = new GetItemSpec() 
   .withPrimaryKey("IDnum", 122) 
   .withProjectionExpression("IDnum, EmployeeName, Department") 
   .withConsistentRead(true);

Item item = table.getItem(spec);
System.out.println(item.toJSONPretty());

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

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

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

package com.amazonaws.codesamples.document;

import java.io.IOException
import java.util.Arrays;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Map;

import com.amazonaws.auth.profile.ProfileCredentialsProvider;
import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DeleteItemOutcome;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.Table;

import com.amazonaws.services.dynamodbv2.document.UpdateItemOutcome;
import com.amazonaws.services.dynamodbv2.document.spec.DeleteItemSpec;
import com.amazonaws.services.dynamodbv2.document.spec.UpdateItemSpec;
import com.amazonaws.services.dynamodbv2.document.utils.NameMap;
import com.amazonaws.services.dynamodbv2.document.utils.ValueMap;
import com.amazonaws.services.dynamodbv2.model.ReturnValue;

public class GetItemOpSample {
   static DynamoDB dynamoDB = new DynamoDB(new AmazonDynamoDBClient(
      new ProfileCredentialsProvider()));
   
   static String tblName = "ProductList";
   public static void main(String[] args) throws IOException {
      createItems();
      retrieveItem();
      
      // Execute updates
      updateMultipleAttributes();
      updateAddNewAttribute();
      updateExistingAttributeConditionally();
      
      // Item deletion
      deleteItem();
   }
   private static void createItems() {
      Table table = dynamoDB.getTable(tblName);
      try {
         Item item = new Item()
            .withPrimaryKey("ID", 303)
            .withString("Nomenclature", "Polymer Blaster 4000")
            .withStringSet( "Manufacturers",
            new HashSet<String>(Arrays.asList("XYZ Inc.", "LMNOP Inc.")))
            .withNumber("Price", 50000)
            .withBoolean("InProduction", true)
            .withString("Category", "Laser Cutter");
            table.putItem(item);
            
         item = new Item()
            .withPrimaryKey("ID", 313)
            .withString("Nomenclature", "Agitatatron 2000")
            .withStringSet( "Manufacturers",
            new HashSet<String>(Arrays.asList("XYZ Inc,", "CDE Inc.")))
            .withNumber("Price", 40000)
            .withBoolean("InProduction", true)
            .withString("Category", "Agitator");
         
         table.putItem(item);
      } catch (Exception e) {
         System.err.println("Cannot create items.");
         System.err.println(e.getMessage());
      }
   }
   private static void retrieveItem() {
      Table table = dynamoDB.getTable(tableName);
      try {
         Item item = table.getItem("ID", 303, "ID, Nomenclature, Manufacturers", null);
         System.out.println("Displaying retrieved items...");
         System.out.println(item.toJSONPretty());
      } catch (Exception e) {
         System.err.println("Cannot retrieve items.");
         System.err.println(e.getMessage());
      }
   }
}