Amazon DynamoDB
开发人员指南 (API Version 2012-08-10)
AWS 服务或AWS文档中描述的功能,可能因地区/位置而异。点 击 Getting Started with Amazon AWS to see specific differences applicable to the China (Beijing) Region.

第 2 步:加载示例数据

在此步骤中,您将使用示例数据填充 Movies 表。

此方案将使用一个示例数据文件,其中包含与 Internet Movie Database (IMDb) 中的数千部电影相关的信息。如以下示例所示,电影数据是 JSON 格式。每部电影各有一个 yeartitle 和一个名为 info 的 JSON 映射。

Copy
[ { "year" : ... , "title" : ... , "info" : { ... } }, { "year" : ..., "title" : ..., "info" : { ... } }, ... ]

在 JSON 数据中,请注意以下事项:

  • 您使用 yeartitle 作为 Movies 表的主键属性值。

  • 您将其余的 info 值存储在名为 info 的单一属性中。此程序说明了如何在 DynamoDB 属性中存储 JSON。

以下是一个电影数据的示例:

Copy
{ "year" : 2013, "title" : "Turn It Down, Or Else!", "info" : { "directors" : [ "Alice Smith", "Bob Jones" ], "release_date" : "2013-01-18T00:00:00Z", "rating" : 6.2, "genres" : [ "Comedy", "Drama" ], "image_url" : "http://ia.media-imdb.com/images/N/O9ERWAU7FS797AJ7LU8HN09AMUP908RLlo5JF90EWR7LJKQ7@@._V1_SX400_.jpg", "plot" : "A rock band plays their music at high volumes, annoying the neighbors.", "rank" : 11, "running_time_secs" : 5215, "actors" : [ "David Matthewman", "Ann Thomas", "Jonathan G. Neff" ] } }

步骤 2.1:下载示例数据文件

  1. 下载示例数据存档:moviedata.zip

  2. 从存档中提取数据文件 (moviedata.json)。

  3. moviedata.json 文件复制并粘贴到当前目录中。

步骤 2.2:将示例数据加载到 Movies 表

下载示例数据后,您可以运行以下程序来填充 Movies 表。

  1. 将以下程序复制并粘贴到您的 Java 开发环境中:

    Copy
    // Copyright 2012-2015 Amazon.com, Inc. or its affiliates. All Rights Reserved. package com.amazonaws.codesamples.gsg; import java.io.File; import java.util.Iterator; import com.amazonaws.client.builder.AwsClientBuilder; import com.amazonaws.services.dynamodbv2.AmazonDynamoDB; import com.amazonaws.services.dynamodbv2.AmazonDynamoDBClientBuilder; 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 MoviesLoadData { public static void main(String[] args) throws Exception { AmazonDynamoDB client = AmazonDynamoDBClientBuilder.standard() .withEndpointConfiguration(new AwsClientBuilder.EndpointConfiguration("http://localhost:8000", "us-west-2")) .build(); DynamoDB dynamoDB = new DynamoDB(client); Table table = dynamoDB.getTable("Movies"); JsonParser parser = new JsonFactory().createParser(new File("moviedata.json")); JsonNode rootNode = new ObjectMapper().readTree(parser); Iterator<JsonNode> iter = rootNode.iterator(); ObjectNode currentNode; while (iter.hasNext()) { currentNode = (ObjectNode) iter.next(); int year = currentNode.path("year").asInt(); String title = currentNode.path("title").asText(); try { table.putItem(new Item().withPrimaryKey("year", year, "title", title).withJSON("info", currentNode.path("info").toString())); System.out.println("PutItem succeeded: " + year + " " + title); } catch (Exception e) { System.err.println("Unable to add movie: " + year + " " + title); System.err.println(e.getMessage()); break; } } parser.close(); } }

    此程序使用开源 Jackson 库来处理 JSON。Jackson 包含在 AWS SDK for Java 中。您不需要单独安装它。

  2. 编译并运行程序。