Dynamodb-creating-items

提供:Dev Guides
移動先:案内検索

DynamoDB-アイテムの作成

DynamoDBでアイテムを作成するには、主にアイテムと属性の指定、および条件を指定するオプションが含まれます。 各アイテムは一連の属性として存在し、各属性には名前が付けられ、特定のタイプの値が割り当てられます。

値タイプには、スカラー、ドキュメント、またはセットが含まれます。 アイテムには400KBのサイズ制限があり、その制限内に収まる属性がいくつでもある可能性があります。 名前と値のサイズ(バイナリおよびUTF-8の長さ)により、アイテムのサイズが決まります。 短い属性名を使用すると、アイテムのサイズを最小限に抑えることができます。

_ -すべてのプライマリキー属性を指定する必要があります。プライマリキーにはパーティションキーのみが必要です。パーティションキーとソートキーの両方を必要とする複合キー。

また、テーブルには事前定義されたスキーマがないことを忘れないでください。 1つのテーブルに劇的に異なるデータセットを保存できます。

このタスクを実行するには、GUIコンソール、Java、または別のツールを使用します。

GUIコンソールを使用してアイテムを作成する方法

コンソールに移動します。 左側のナビゲーションペインで、テーブル*を選択します。 宛先として使用するテーブル名を選択し、次のスクリーンショットに示すように[*アイテム]タブを選択します。

アイテムの作成

  • アイテムの作成*を選択します。 [アイテムの作成]画面には、必要な属性値を入力するためのインターフェイスがあります。 セカンダリインデックスも入力する必要があります。

アイテムの作成を選択

さらに属性が必要な場合は、メッセージ*の左側にあるアクションメニューを選択します。 次に、*追加、および目的のデータ型を選択します。

メッセージ

すべての重要な情報を入力したら、[保存]を選択してアイテムを追加します。

アイテム作成でJavaを使用する方法

アイテム作成操作でJavaを使用するには、DynamoDBクラスインスタンス、テーブルクラスインスタンス、アイテムクラスインスタンスを作成し、作成するアイテムのプライマリキーと属性を指定します。 次に、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);

次の大きな例を見ることもできます。

_ -次のサンプルでは、​​以前に作成されたデータソースを想定しています。 実行を試みる前に、サポートライブラリを取得し、必要なデータソース(必要な特性を持つテーブル、または他の参照ソース)を作成します。

次のサンプルでは、​​Eclipse IDE、AWS認証情報ファイル、およびEclipse AWS Javaプロジェクト内のAWS Toolkitも使用しています。

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