DynamoDB - Table de chargement

Le chargement d'une table consiste généralement à créer un fichier source, à s'assurer que le fichier source est conforme à une syntaxe compatible avec DynamoDB, à envoyer le fichier source à la destination, puis à confirmer un remplissage réussi.

Utilisez la console GUI, Java ou une autre option pour effectuer la tâche.

Charger la table à l'aide de la console GUI

Chargez les données à l'aide d'une combinaison de la ligne de commande et de la console. Vous pouvez charger des données de plusieurs manières, dont certaines sont les suivantes -

  • La console
  • La ligne de commande
  • Code et aussi
  • Pipeline de données (une fonctionnalité abordée plus loin dans le didacticiel)

Cependant, pour la vitesse, cet exemple utilise à la fois le shell et la console. Tout d'abord, chargez les données source dans la destination avec la syntaxe suivante -

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

Par exemple -

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

Vérifiez le succès de l'opération en accédant à la console à -

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

Choisir Tables dans le volet de navigation et sélectionnez la table de destination dans la liste des tables.

Sélectionnez le Itemsonglet pour examiner les données que vous avez utilisées pour remplir le tableau. SélectionnerCancel pour revenir à la liste des tableaux.

Charger la table à l'aide de Java

Utilisez Java en créant d'abord un fichier source. Notre fichier source utilise le format JSON. Chaque produit a deux attributs de clé primaire (ID et Nomenclature) et une carte JSON (Stat) -

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

Vous pouvez consulter l'exemple suivant -

{ 
   "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." 
   } 
}

L'étape suivante consiste à placer le fichier dans le répertoire utilisé par votre application.

Java utilise principalement le putItem et path methods pour effectuer le chargement.

Vous pouvez consulter l'exemple de code suivant pour traiter un fichier et le charger -

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