DynamoDB - लोड टेबल

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

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

जीयूआई कंसोल का उपयोग करके लोड टेबल

कमांड लाइन और कंसोल के संयोजन का उपयोग करके डेटा लोड करें। आप कई तरीकों से डेटा लोड कर सकते हैं, जिनमें से कुछ इस प्रकार हैं -

  • सांत्वना
  • कमांड लाइन
  • कोड और भी
  • डेटा पाइपलाइन (ट्यूटोरियल में बाद में चर्चा की गई सुविधा)

हालाँकि, गति के लिए, यह उदाहरण शेल और कंसोल दोनों का उपयोग करता है। सबसे पहले, स्रोत डेटा को निम्नलिखित सिंटैक्स के साथ गंतव्य में लोड करें -

aws dynamodb batch-write-item -–request-items file://[filename]

उदाहरण के लिए -

aws dynamodb batch-write-item -–request-items file://MyProductData.json

कंसोल पर पहुँच कर ऑपरेशन की सफलता की जाँच करें -

https://console.aws.amazon.com/dynamodb

चुनें Tables नेविगेशन फलक से, और तालिका सूची से गंतव्य तालिका का चयन करें।

को चुनिए Itemsटैब उस डेटा की जांच करने के लिए जिसे आपने तालिका को पॉप्युलेट करने के लिए उपयोग किया था। चुनते हैंCancel तालिका सूची में वापस जाने के लिए।

जावा का उपयोग करके लोड टेबल

जावा को पहले सोर्स फाइल बनाकर रोजगार दें। हमारी स्रोत फ़ाइल JSON प्रारूप का उपयोग करती है। प्रत्येक उत्पाद में दो प्राथमिक मुख्य गुण होते हैं (आईडी और नामकरण) और एक JSON मानचित्र (स्टेट) -

[ 
   { 
      "ID" : ... , 
      "Nomenclature" : ... , 
      "Stat" : { ... }
   }, 
   { 
      "ID" : ... , 
      "Nomenclature" : ... , 
      "Stat" : { ... } 
   }, 
    ... 
]

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

{ 
   "ID" : 122, 
   "Nomenclature" : "Particle Blaster 5000", 
   "Stat" : { 
      "Manufacturer" : "XYZ Inc.", 
      "sales" : "1M+", 
      "quantity" : 500, 
      "img_src" : "http://www.xyz.com/manuals/particleblaster5000.jpg", 
      "description" : "A laser cutter used in plastic manufacturing." 
   } 
}

अगला चरण आपके एप्लिकेशन द्वारा उपयोग की गई निर्देशिका में फ़ाइल को रखना है।

जावा मुख्य रूप से उपयोग करता है putItem तथा path methods लोड करने के लिए।

आप फ़ाइल को संसाधित करने और उसे लोड करने के लिए निम्न कोड उदाहरण की समीक्षा कर सकते हैं -

import java.io.File;
import java.util.Iterator;

import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClient;
import com.amazonaws.services.dynamodbv2.document.DynamoDB;
import com.amazonaws.services.dynamodbv2.document.Item;
import com.amazonaws.services.dynamodbv2.document.Table;

import com.fasterxml.jackson.core.JsonFactory;
import com.fasterxml.jackson.core.JsonParser;
import com.fasterxml.jackson.databind.JsonNode;
import com.fasterxml.jackson.databind.ObjectMapper
import com.fasterxml.jackson.databind.node.ObjectNode;

public class ProductsLoadData {  
   public static void main(String[] args) throws Exception {  
      AmazonDynamoDBClient client = new AmazonDynamoDBClient() 
         .withEndpoint("http://localhost:8000");  
      
      DynamoDB dynamoDB = new DynamoDB(client);  
      Table table = dynamoDB.getTable("Products");  
      JsonParser parser = new JsonFactory() 
         .createParser(new File("productinfo.json"));  
      
      JsonNode rootNode = new ObjectMapper().readTree(parser); 
      Iterator<JsonNode> iter = rootNode.iterator();  
      ObjectNode currentNode;  
      
      while (iter.hasNext()) { 
         currentNode = (ObjectNode) iter.next();  
         int ID = currentNode.path("ID").asInt(); 
         String Nomenclature = currentNode.path("Nomenclature").asText();  
         
         try { 
            table.putItem(new Item() 
               .withPrimaryKey("ID", ID, "Nomenclature", Nomenclature) 
               .withJSON("Stat", currentNode.path("Stat").toString()));
            System.out.println("Successful load: " + ID + " " + Nomenclature);  
         } catch (Exception e) {
            System.err.println("Cannot add product: " + ID + " " + Nomenclature);
            System.err.println(e.getMessage()); 
            break; 
         } 
      } 
      parser.close(); 
   } 
}