DynamoDB - आइटम बनाना

DynamoDB में एक आइटम बनाना मुख्य रूप से आइटम और विशेषता विनिर्देश, और निर्दिष्ट शर्तों का विकल्प होता है। प्रत्येक आइटम विशेषताओं के एक सेट के रूप में मौजूद है, जिसमें प्रत्येक विशेषता को एक निश्चित प्रकार के मूल्य के नाम और असाइन किया गया है।

मान प्रकार में स्केलर, दस्तावेज़ या सेट शामिल हैं। आइटम 400KB आकार की सीमा को वहन करते हैं, उस सीमा के भीतर फिटिंग करने में सक्षम किसी भी राशि की संभावना के साथ। नाम और मूल्य आकार (बाइनरी और UTF-8 लंबाई) आइटम का आकार निर्धारित करते हैं। छोटी विशेषता नाम का उपयोग करके आइटम आकार को कम करना है।

Note- आपको सभी प्राथमिक कुंजी विशेषताओं को निर्दिष्ट करना होगा, प्राथमिक कुंजी के साथ केवल विभाजन कुंजी की आवश्यकता होगी; और कम्पोज़िट कीज़ को विभाजन और सॉर्ट कुंजी दोनों की आवश्यकता होती है।

इसके अलावा, याद रखें कि टेबल में कोई पूर्वनिर्धारित स्कीमा नहीं है। आप एक तालिका में नाटकीय रूप से अलग डेटासेट स्टोर कर सकते हैं।

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

GUI कंसोल का उपयोग करके आइटम कैसे बनाएं?

कंसोल पर नेविगेट करें। बाईं ओर नेविगेशन फलक में, का चयन करेंTables। गंतव्य के रूप में उपयोग के लिए तालिका का नाम चुनें, और फिर चुनेंItems निम्न स्क्रीनशॉट में दिखाया गया टैब।

चुनते हैं Create Item। आइटम बनाएँ स्क्रीन आवश्यक विशेषता मान दर्ज करने के लिए एक इंटरफ़ेस प्रदान करता है। किसी भी द्वितीयक सूचक को भी दर्ज किया जाना चाहिए।

यदि आपको अधिक विशेषताओं की आवश्यकता है, तो बाईं ओर स्थित एक्शन मेनू चुनें Message। फिर सेलेक्ट करेंAppend, और वांछित डेटा प्रकार।

सभी आवश्यक जानकारी दर्ज करने के बाद, चयन करें Save आइटम जोड़ने के लिए।

आइटम निर्माण में जावा का उपयोग कैसे करें?

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

उदाहरण

DynamoDB dynamoDB = new DynamoDB (new AmazonDynamoDBClient(
   new ProfileCredentialsProvider()));
Table table = dynamoDB.getTable("ProductList");
   
// Spawn a related items list 
List<Number> RELItems = new ArrayList<Number>(); 
RELItems.add(123); 
RELItems.add(456); 
RELItems.add(789);  
   
//Spawn a product picture map  
Map<String, String> photos = new HashMap<String, String>(); 
photos.put("Anterior", "http://xyz.com/products/101_front.jpg"); 
photos.put("Posterior", "http://xyz.com/products/101_back.jpg"); 
photos.put("Lateral", "http://xyz.com/products/101_LFTside.jpg");  

//Spawn a product review map 
Map<String, List<String>> prodReviews = new HashMap<String, List<String>>();  
List<String> fiveStarRVW = new ArrayList<String>(); 
fiveStarRVW.add("Shocking high performance."); 
fiveStarRVW.add("Unparalleled in its market."); 
prodReviews.put("5 Star", fiveStarRVW);  
List<String> oneStarRVW = new ArrayList<String>(); 
oneStarRVW.add("The worst offering in its market."); 
prodReviews.put("1 Star", oneStarRVW);  

// Generate the item 
Item item = new Item()
   .withPrimaryKey("Id", 101) 
   .withString("Nomenclature", "PolyBlaster 101") 
   .withString("Description", "101 description") 
   .withString("Category", "Hybrid Power Polymer Cutter")  
   .withString("Make", "Brand – XYZ") 
   .withNumber("Price", 50000) 
   .withString("ProductCategory", "Laser Cutter") 
   .withBoolean("Availability", true) 
   .withNull("Qty") 
   .withList("ItemsRelated", RELItems) 
   .withMap("Images", photos) 
   .withMap("Reviews", prodReviews);

// Add item to the table  
PutItemOutcome outcome = table.putItem(item);

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

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 CreateItemOpSample { 
   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()); 
      } 
   }   
}